box-shadow
属性用于在元素的框架上添加阴影效果。 你可以在同一个元素上设置多个阴影效果,并用 逗号 将他们分隔开。 该属性可设置的值包括阴影的X轴偏移量
、Y轴偏移量
、模糊半径
、扩散半径
和颜色
。
box-shadow: [inset]<offset-x>
<offset-y>
[<blur-radius>
] [] color [,]
规则:(当给出两个、三个或四个值时)
- 如果只给出两个值, 那么这两个值将会被当作
<offset-x>
<offset-y>
来解释。 <offset-x>
设置水平偏移量,正值阴影则位于元素右边,负值阴影则位于元素左边 <offset-y>
设置垂直偏移量,正值阴影则位于元素下方,负值阴影则位于元素上方
- 如果给出了第三个值, 那么第三个值将会被当作
<blur-radius>
解释。 值越大,模糊面积越大,阴影越大越淡。不能为负值。
- 如果给出了第四个值, 那么第四个值将会被当作
<spread-radius>
解释。 取正值时,阴影扩大;取负值时,阴影收缩。默认为0,此时阴影与元素同样大。需要考虑 inset。
- 可选,
inset
关键字。默认阴影在边框外,即阴影向外扩散。使用 inset
关键字 会使得阴影落在盒子内部。 此时阴影会在边框之内 、背景之上、内容之下。
- 可选,
<color>
值。
观察图中四色方块可知:第三个数值(模糊半径)控制模糊程度,不改变阴影大小;第四个数值(扩散半径)会改变阴影大小,正值→阴影扩展,负值→阴影收缩。
常见问题: 制作单边阴影时,明明设置了x,y轴方向的偏移,为什么别的边还是有阴影出现?
解决方案:增加此边所在方向的偏移量(数值大小与正负),并适当缩小阴影大小(第四个数值为负值),减少模糊半径的视觉影响;
各种阴影的书写方式