CSS3--实现特殊阴影 (实例)

学习来源:慕课网http://www.imooc.com/view/240

先看效果图↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓↓

 

 HTML结构

 1 <body>
 2     <div class="wrap effect">    
 3     <!-- effect类:是阴影类,其他元素也可以使用 -->
 4         <h1>Shadow Effect</h1>
 5     </div>
 6     <ul class="box">
 7         <li><img src="images/photo1.jpg" alt=""></li>
 8         <li><img src="images/photo2.jpg" alt=""></li>
 9         <li><img src="images/photo3.jpg" alt=""></li>
10     </ul>
11 </body>

CSS样式(省略了各浏览器前缀)

 1 /*通用类*/
 2 body { font-family: Arial; font-size: 20px;}
 3 body,ul {margin: 0; padding: 0; list-style: none;}
 4 .wrap {width:70%; height:200px; margin:50px auto; background: #fff; }
 5 .wrap h1 {font-size: 20px; text-align: center; line-height: 200px; }
 6 
 7 /*弧度阴影*/
 8 .effect { 
 9     position: relative;
10     box-shadow: 0px 1px 4px rgba(0,0,0,0.3),
11     0 0 10px rgba(0,0,0,0.1) inset; 
12     /*添加一个范围=4px的小阴影;再添加一个范围=10px的内阴影;*/
13 }
14 .effect:before,.effect:after {
15     content: '';
16     background: #f00;
17     position: absolute;
18     z-index: -2;
19     top:50%; bottom:0; left:30px; right:30px;
20     /*设置四个方向值,然后浏览器自动计算盒子的大小;*/
21     box-shadow: 0px 0px 20px rgba(0,0,0,0.8);
22     /*设置添加的盒子的阴影;*/
23     border-radius: 100px/10px;
24     /*添加圆角:水平方向圆角大小是100px/垂直方向圆角大小是10px;*/
25 }
26 
27 /*翘边阴影*/
28 .box{
29     width:980px;
30     height:auto;
31     clear:both;
32     overflow:hidden;
33     margin:20px auto;
34 }
35 .box li{
36     position: relative;
37     /*以li为定位基准;*/
38     width:300px;
39     height:210px;
40     float:left;
41     background: #fff;
42     margin:20px 10px;
43     border:2px solid #efefef;
44     box-shadow: 0px 1px 4px rgba(0,0,0,0.27);
45     /*给li添加一个小小的阴影;*/
46 }
47 .box li img {
48     display: block;
49     width:290px;
50     height:200px;
51     margin:5px;
52 }
53 .box li:before{
54     content: '';
55     position: absolute;
56     z-index: -3;
57     width:90%;
58     height:80%;
59     left:18px;
60     bottom:8px;
61     box-shadow: 0px 8px 20px rgba(0,0,0,0.6);
62     transform:skew(-12deg) rotate(-4deg);
63     /*图形向右倾斜12度;并逆时针旋转4度;*/
64 }
65 .box li:after{
66     content: '';
67     position: absolute;
68     z-index: -4;
69     width:90%;
70     height:80%;
71     right:18px;
72     bottom:8px;
73     box-shadow: 0px 8px 20px rgba(0,0,0,0.6);
74     transform:skew(12deg) rotate(4deg);
75     /*图形向左倾斜12度;并顺时针旋转4度;*/
76 }

之前在PS里用灰色图层叠加在其他图层下面做特殊阴影效果,相同思路应用到CSS里了。赞!

知识点补充↓↓↓↓↓↓↓

 1 1.box-shadow--添加一个或多个阴影
 2     >1.功能:box-shadow--添加一个或多个阴影;
 3     >2.语法:box-shadow:h-shadow v-shadow blur spread color inset;
 4     >3.参数:
 5         >>:h-shadow(必需):水平阴影的位置;允许负值;
 6         >>:v-shadow(必需):垂直阴影的位置;允许负值;
 7         >>:blur(可选):模糊距离;
 8         >>:spread(可选):阴影的尺寸;
 9         >>:color(可选):阴影的颜色;
10         >>:inset(可选):将外部阴影(outset)改为内部阴影;
11     >4.浏览器:IE9+/FF4
12 
13 2.:before与:after 
14     >1.:before选择器:在被选元素的内容前面插入内容;
15     >2.:after选择器:在被选元素的内容后面插入内容;
16     >3.说明:需要使用content属性来指定要插入的内容;
17     >4.浏览器:IE8及更早版本中的:after,必须使用<!DOCTYPE>;
18 
19 3.transform--
20     >1.功能:向元素应用2D或3D转换
21     >1.语法:transform:none | transform-functions
22     >2.参数:
23         >>:skew(x-angle,y-angle):定义沿着X和Y轴的2D倾斜转换;
24         >>:skewX(angle):定义沿着X轴的2D倾斜转换;
25         >>:skewY(angle):定义沿着Y轴的2D倾斜转换;

 

posted @ 2015-02-05 17:39  翌子涵  阅读(6854)  评论(1编辑  收藏  举报