CSS3 box-shadow 属性用来描述一个元素的一个或多个阴影效果,该属性几乎可以让你完成你想要的任何阴影效果。然而 box-shadow 属性语法和取值非常灵活,对于新手有点不容易理解。今天总结一下语法和 box-shadow 属性各种阴影效果。

    1. /* x偏移量 | y偏移量 | 阴影颜色 */
    2. box-shadow: 60px -16px teal;
    3. /* x偏移量 | y偏移量 | 阴影模糊半径 | 阴影颜色 */
    4. box-shadow: 10px 5px 5px black;
    5. /* x偏移量 | y偏移量 | 阴影模糊半径 | 阴影扩散半径 | 阴影颜色 */
    6. box-shadow: 2px 2px 2px 1px rgba(0, 0, 0, 0.2);
    7. /* 插页(阴影向内) | x偏移量 | y偏移量 | 阴影颜色 */
    8. box-shadow: inset 5em 1em gold;
    9. /* 任意数量的阴影,以逗号分隔 */
    10. box-shadow: 3px 3px red, -1em 0 0.4em olive;
    11. /* 全局关键字 */
    12. box-shadow: inherit;
    13. box-shadow: initial;
    14. box-shadow: unset;

    说明:

    • inset: 默认阴影在边框外。使用 inset 后,阴影在边框内(即使是透明边框),背景之上内容之下。也有些人喜欢把这个值放在最后,浏览器也支持。
    • <offset-x> <offset-y>: 这是头两个 <length>值,用来设置阴影偏移量。<offset-x> 设置水平偏移量,如果是负值则阴影位于元素左边。 <offset-y> 设置垂直偏移量,如果是负值则阴影位于元素上面。可用单位请查看 <length>。如果两者都是0,那么阴影位于元素后面。这时如果设置了 <blur-radius><spread-radius> 则有模糊效果。
    • <blur-radius>: 这是第三个 <length> 值。值越大,模糊面积越大,阴影就越大越淡。 不能为负值。默认为0,此时阴影边缘锐利。
    • <spread-radius> : 这是第四个 <length> 值。取正值时,阴影扩大;取负值时,阴影收缩。默认为0,此时阴影与元素同样大。
    • <color> : 相关事项查看 <color> 。如果没有指定,则由浏览器决定——通常是color的值,不过目前Safari取透明。

    image.png
    image.png
    image.png

    1. div {
    2. width: 150px;
    3. height: 150px;
    4. background-color: #fff;
    5. box-shadow: 120px 80px 40px 20px #0ff;
    6. /* 顺序为: offset-x, offset-y, blur-size, spread-size, color */
    7. /* blur-size 和 spread-size 是可选的 (默认为 0) */
    8. }

    image.png

    1. .boxshadow1{ box-shadow:inset 0px 0px 5px 1px #000; } //内阴影
    2. .boxshadow2{ box-shadow:inset 0 1px 2px 1px #000; } //3边内影
    3. .boxshadow3{box-shadow:0 0 10px #000;} //外阴影
    4. .boxshadow4{box-shadow:2px 2px 5px #000;} //右下外阴影
    5. .boxshadow5{box-shadow:0 0 5px 15px #000;} //扩大阴影
    6. .boxshadow6{box-shadow: 12px 12px 2px 1px rgba(0, 0, 255, .2);} //半透明阴影色
    1. .boxshadow1{ box-shadow:inset 0px 15px 10px -15px #000; } //上边内阴影 -15抵消
    2. .boxshadow2{ box-shadow:inset -15px 0px 10px -15px #000;} //右边内阴影
    3. .boxshadow3{box-shadow:0px 12px 8px -12px #000; border-radius:10px; } //下边外阴影
    4. .boxshadow4{box-shadow:3px 0 8px -4px #000;} //右边外阴影
    5. .boxshadow5{ box-shadow: inset 0px -1px 0px 0px rgb(0, 0, 0) ;} //下边细线
    1. //上下边内阴影
    2. .boxshadow1{
    3. box-shadow:inset 0px 15px 15px -15px #000,
    4. inset 0px -15px 15px -15px #000;
    5. }
    6. //左右边外阴影
    7. .boxshadow2{
    8. box-shadow:15px 0 15px -15px #000,
    9. -15px 0 15px -15px #000;
    10. }
    11. //多层阴影
    12. .boxshadow3{ border-radius:10px;
    13. box-shadow:0px 0px 0px 3px #bb0a0a,
    14. 0px 0px 0px 6px #2e56bf,
    15. 0px 0px 0px 9px #ea982e;
    16. }
    1. <div class="box11 shadow"></div>
    2. .box11 {
    3. width: 300px;
    4. height: 100px;
    5. background: #ccc;
    6. border-radius: 10px;
    7. margin: 10px;
    8. }
    9. .shadow {
    10. position: relative;
    11. max-width: 270px;
    12. box-shadow: 0px 1px 4px rgba(0,0,0,0.3),
    13. 0px 0px 20px rgba(0,0,0,0.1) inset;
    14. }
    15. .shadow::before,
    16. .shadow::after {
    17. content:"";
    18. position:absolute;
    19. z-index:-1;
    20. }
    21. .shadow::before,
    22. .shadow::after {
    23. content:"";
    24. position:absolute;
    25. z-index:-1;
    26. bottom:15px;
    27. left:10px;
    28. width:50%;
    29. height:20%;
    30. }
    31. .shadow::before,
    32. .shadow::after {
    33. content:"";
    34. position:absolute;
    35. z-index:-1;
    36. bottom:15px;
    37. left:10px;
    38. width:50%;
    39. height:20%;
    40. box-shadow:0 15px 10px rgba(0, 0, 0, 0.7);
    41. transform:rotate(-3deg);
    42. }
    43. .shadow::after{
    44. right:10px;
    45. left:auto;
    46. transform:rotate(3deg);
    47. }
    1. <div class="wrap">
    2. <div class="box box1 shadow1">
    3. <h3>Shadow 1</h3>
    4. </div>
    5. <div class="box box2 shadow2">
    6. <h3>Shadow 2</h3>
    7. </div>
    8. <div class="box box3 shadow3">
    9. <h3>Shadow 3</h3>
    10. </div>
    11. <div class="box box4 shadow4">
    12. <h3>Shadow 4</h3>
    13. </div>
    14. <div class="box box5 shadow5">
    15. <h3>Shadow 5</h3>
    16. </div>
    17. <div class="box box6 shadow6">
    18. <h3>Shadow 6</h3>
    19. </div>
    20. <div class="box box7 shadow7">
    21. <h3>Shadow 7</h3>
    22. </div>
    23. <div class="box box8 shadow8">
    24. <h3>Shadow 8</h3>
    25. </div>
    26. </div>
    27. background:#E6EEF6;
    28. }
    29. .wrap{
    30. margin-left:20px;
    31. }
    32. .box{
    33. width:40%;
    34. height:200px;
    35. float:left;
    36. background-color:white;
    37. margin:25px 15px;
    38. border-radius:5px;
    39. }
    40. .box h3{
    41. font-family: 'Didact Gothic', sans-serif;
    42. font-weight:normal;
    43. text-align:center;
    44. padding-top:60px;
    45. color:#fff;
    46. }
    47. .box1{
    48. background-color: #EBA39E;
    49. }
    50. .box2{
    51. background-color: #EDE89A;
    52. }
    53. .box3{
    54. background-color: #9EEBA1;
    55. }
    56. .box4{
    57. background-color: #9EEBBF;
    58. }
    59. .box5{
    60. background-color: #9ED9EB;
    61. }
    62. .box6{
    63. background-color: #9EB3EB;
    64. }
    65. .box7{
    66. background-color: #DB9EEB;
    67. }
    68. .box8{
    69. background-color: #C49EEB;
    70. }
    71. .shadow1, .shadow2, .shadow3,.shadow4,.shadow5,.shadow6,.shadow7,.shadow8{
    72. position:relative;
    73. }
    74. .shadow1,.shadow2,.shadow3,.shadow4,.shadow5,.shadow6,.shadow7,.shadow8{
    75. box-shadow:0 1px 4px rgba(0, 0, 0, 0.3), 0 0 20px rgba(0, 0, 0, 0.1) inset;
    76. }
    77. /*****************************************************************dashed border
    78. ****************************************************************/
    79. .shadow1 h3, .shadow2 h3, .shadow3 h3, .shadow4 h3, .shadow5 h3, .shadow6 h3, .shadow7 h3, .shadow8 h3{
    80. width:87%;
    81. height:100px;
    82. margin-left:6%;
    83. border:2px dashed #F7EEEE;
    84. border-radius:5px;
    85. }
    86. /****************************************************************
    87. *styling shadows
    88. ****************************************************************/
    89. .shadow1:before, .shadow1:after{
    90. position:absolute;
    91. content:"";
    92. bottom:12px;left:15px;top:80%;
    93. width:45%;
    94. background:#9B7468;
    95. z-index:-1;
    96. -webkit-box-shadow: 0 20px 15px #9B7468;
    97. -moz-box-shadow: 0 20px 15px #9B7468;
    98. box-shadow: 0 20px 15px #9B7468;
    99. -webkit-transform: rotate(-6deg);
    100. -moz-transform: rotate(-6deg);
    101. transform: rotate(-6deg);
    102. }
    103. .shadow1:after{
    104. -webkit-transform: rotate(6deg);
    105. -moz-transform: rotate(6deg);
    106. transform: rotate(6deg);
    107. right: 15px;left: auto;
    108. }
    109. .shadow2:before{
    110. position:absolute;
    111. content:"";
    112. width:80%;
    113. top:140px;bottom:15px;left:30px;
    114. background-color:#9F8641;
    115. z-index:-1;
    116. -webkit-box-shadow:0 23px 17px 0 #9F8641;
    117. -moz-box-shadow:0 23px 17px 0 #9F8641;
    118. box-shadow: 0 23px 17px 0 #9F8641;
    119. -webkit-transform:rotate(-4deg);
    120. -moz-transform:rotate(-4deg);
    121. transform:rotate(-4deg);
    122. }
    123. .shadow3:before, .shadow3:after{
    124. content:"";
    125. position:absolute;
    126. bottom:0;top:2px;left:15px;right:15px;
    127. z-index:-1;
    128. border-radius:100px/30px;
    129. -webkit-box-shadow:0 0 30px 2px #479F41;
    130. -moz-box-shadow:0 0 30px 2px #479F41;
    131. box-shadow: 0 0 30px 2px #479F41;
    132. }
    133. .shadow4:before, .shadow4:after{
    134. position:absolute;
    135. content:"";
    136. top:14px;bottom:14px;left:0;right:0;
    137. box-shadow:0 0 25px 3px #548E7F;
    138. border-radius:100px/10px;
    139. z-index:-1;
    140. }
    141. .shadow5:before, .shadow5:after{
    142. position:absolute;
    143. content:"";
    144. box-shadow:0 10px 25px 20px #518C96;
    145. top:40px;left:10px;bottom:50px;
    146. width:15%;
    147. z-index:-1;
    148. -webkit-transform: rotate(-8deg);
    149. -moz-transform: rotate(-8deg);
    150. transform: rotate(-8deg);
    151. }
    152. .shadow5:after{
    153. -webkit-transform: rotate(8deg);
    154. -moz-transform: rotate(8deg);
    155. transform: rotate(8deg);
    156. right: 10px;left: auto;
    157. }
    158. .shadow6:before, .shadow6:after{
    159. position:absolute;
    160. content:"";
    161. top:100px;bottom:5px;left:30px;right:30px;
    162. z-index:-1;
    163. box-shadow:0 0 40px 13px #486685;
    164. border-radius:100px/20px;
    165. }
    166. .shadow7:before, .shadow7:after{
    167. position:absolute;
    168. content:"1";
    169. top:25px;left:20px;bottom:150px;
    170. width:80%;
    171. z-index:-1;
    172. -webkit-transform: rotate(-6deg);
    173. -moz-transform: rotate(-6deg);
    174. transform: rotate(-6deg);
    175. }
    176. .shadow7:before{
    177. box-shadow:10px -10px 30px 15px #984D8E;
    178. }
    179. .shadow7:after{
    180. -webkit-transform: rotate(7deg);
    181. -moz-transform: rotate(7deg);
    182. transform: rotate(7deg);
    183. bottom: 25px;top: auto;
    184. box-shadow:10px 10px 30px 15px #984D8E;
    185. }
    186. .shadow8{
    187. box-shadow:
    188. -6px -6px 8px -4px rgba(250,254,118,0.75),
    189. 6px -6px 8px -4px rgba(254,159,50,0.75),
    190. 6px 6px 8px -4px rgba(255,255,0,0.75),
    191. 6px 6px 8px -4px rgba(0,0,255,2.75);
    192. }