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

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

HTML结构

 <body>
<div class="wrap effect">
<!-- effect类:是阴影类,其他元素也可以使用 -->
<h1>Shadow Effect</h1>
</div>
<ul class="box">
<li><img src="data:images/photo1.jpg" alt=""></li>
<li><img src="data:images/photo2.jpg" alt=""></li>
<li><img src="data:images/photo3.jpg" alt=""></li>
</ul>
</body>

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

 /*通用类*/
body { font-family: Arial; font-size: 20px;}
body,ul {margin:; padding:; list-style: none;}
.wrap {width:70%; height:200px; margin:50px auto; background: #fff; }
.wrap h1 {font-size: 20px; text-align: center; line-height: 200px; } /*弧度阴影*/
.effect {
position: relative;
box-shadow: 0px 1px 4px rgba(0,0,0,0.3),
0 0 10px rgba(0,0,0,0.1) inset;
/*添加一个范围=4px的小阴影;再添加一个范围=10px的内阴影;*/
}
.effect:before,.effect:after {
content: '';
background: #f00;
position: absolute;
z-index: -2;
top:50%; bottom:; left:30px; right:30px;
/*设置四个方向值,然后浏览器自动计算盒子的大小;*/
box-shadow: 0px 0px 20px rgba(0,0,0,0.8);
/*设置添加的盒子的阴影;*/
border-radius: 100px/10px;
/*添加圆角:水平方向圆角大小是100px/垂直方向圆角大小是10px;*/
} /*翘边阴影*/
.box{
width:980px;
height:auto;
clear:both;
overflow:hidden;
margin:20px auto;
}
.box li{
position: relative;
/*以li为定位基准;*/
width:300px;
height:210px;
float:left;
background: #fff;
margin:20px 10px;
border:2px solid #efefef;
box-shadow: 0px 1px 4px rgba(0,0,0,0.27);
/*给li添加一个小小的阴影;*/
}
.box li img {
display: block;
width:290px;
height:200px;
margin:5px;
}
.box li:before{
content: '';
position: absolute;
z-index: -3;
width:90%;
height:80%;
left:18px;
bottom:8px;
box-shadow: 0px 8px 20px rgba(0,0,0,0.6);
transform:skew(-12deg) rotate(-4deg);
/*图形向右倾斜12度;并逆时针旋转4度;*/
}
.box li:after{
content: '';
position: absolute;
z-index: -4;
width:90%;
height:80%;
right:18px;
bottom:8px;
box-shadow: 0px 8px 20px rgba(0,0,0,0.6);
transform:skew(12deg) rotate(4deg);
/*图形向左倾斜12度;并顺时针旋转4度;*/
}

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

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

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

CSS3--实现特殊阴影 (实例)的更多相关文章

  1. CSS3知识之阴影box-shadow

    一.定义和用法 box-shadow 属性向框添加一个或多个阴影. box-shadow: h-shadow v-shadow blur spread color inset; h-shadow   ...

  2. css3照片墙+曲线阴影

    css3照片墙+曲线阴影 最近在学习jquery,晚上想复习下以前学过的知识,看到网上有关于css3照片墙的,感觉挺好玩的,就做了做.(以下图片均来自网络) 一.css3照片墙 html部分: < ...

  3. 转载---CSS3实现曲线阴影和翘边阴影

    预备知识 DIV+CSS基础 圆角:border-radius 2D变换:transform:skew && rotate 伪类::before 和 :after 代码 HTML结构代 ...

  4. IE下实现类似CSS3 text-shadow文字阴影的几种方法

    IE下实现类似CSS3 text-shadow文字阴影的几种方法 一.开始的擦边话 为了测试IE9浏览器,下午晃晃荡荡把系统换成window7的了.果然,正如网上所传言的一样,IE9浏览器确实不支持C ...

  5. CSS3 文本效果(阴影)

    CSS3中包含几个新的文本特征. 在本章中您将了解以下文本属性: text-shadow box-shadow text-overflow word-wrap word-break CSS3 的文本阴 ...

  6. CSS3实现带阴影的弹球

    实现div上下跳动时,底部阴影随着变化 <!DOCTYPE html> <html lang="en"> <head> <meta cha ...

  7. Long Shadows Generate是一款在线使用纯CSS3实现长阴影的效果,一款强大的扁平化长投影制造器。

    Long Shadows Generate是一款在线使用纯CSS3实现长阴影的效果,一款强大的扁平化长投影制造器. Long Shadows Generate 彩蛋爆料直击现场 Long Shadow ...

  8. Css3阴影实例

    阴影大约从CSS2就开始有了,但是只有Safari一个浏览器支持它,到现在依然是这样.阴影在CSS3中可以应用在边框和文字上,就像图片的阴影效果一样.一般可以分为: box-shadow textsh ...

  9. CSS3的文字阴影—text-shadow

    text-shadow还没有出现时,大家在网页设计中阴影一般都是用photoshop做成图片,现在有了css3可以直接使用text-shadow属性来指定阴影. 这个属性可以有两个作用,产生阴影和模糊 ...

  10. IE6下完美兼容css3圆角和阴影属性的htc插件PIE.htc

    1.(推荐:)css插件PIE.htc,这个才是真正完美兼容css3的圆角和阴影属性在IE6环境下使用的效果,但要注意的是:下面的代码必须写在html文件的head标签内,否则无效(不能从外部引用下面 ...

随机推荐

  1. 深入理解Oracle索引(25):一招鲜、吃遍天之单字段索引创建思路

    本文较短.不过实用性很好.还是记录之.          ㈠ 先别看SQL语句.看执行计划.挑出走全表扫的表 ㈡ 回头看SQL语句.分析上述表的约束字段有哪些.检查各个约束字段的索引是否存在 ㈢ 选择 ...

  2. 10分钟学会基于ASP.NET的 JQuery实例 (转)

    本文介绍如何在ASP.NET(ASP.NET/AJAX)里使用基于JQuery的AJAX技术.(源代码下载见最后) 在使用JQuery前,请到www.jquery.com下载最新版本的js代码,然后再 ...

  3. scenes & segues within storyboards

    Scenes Scenes in a storyboard represent content shown within one screen in your application. A scene ...

  4. [Angular 2] Nesting Elements in Angular 2 Components with ng-content (AKA Angular 2 Transclusion)

    You can place content inside of the instance of your component element then manage it inside of the ...

  5. android安卓最新快捷环境搭建(转)

    现在很多视频和文章上的安卓环境搭建还是比较老的,挺麻烦.现在写快速方便的搭建: 一.下载JDK: 网址:http://www.oracle.com/technetwork/java/javase/do ...

  6. Java HttpClient使用小结

    httpclient是apache的一个项目:http://hc.apache.org/ 文档比較完好:http://hc.apache.org/httpcomponents-client-ga/tu ...

  7. 内存管理和@property的属性

    内存管理和@property的属性 目录 对内存管理的理解 Objective C内存管理方式 内存的管理 对象的所有权和内存管理原则 合理解决内存管理带来的问题 自动释放池 @property的属性 ...

  8. CSS 居中大全【转】

    我看最近微博流行 CSS 居中技术,老外码农争相写相关的文章,一篇赛一篇的长啊,我把几篇归纳总结了一下,算是笔记. 孔乙己曾说:“茴香豆的回字有四种写法”,万一哪天有个面试官问你:“居中一共有几种写法 ...

  9. 学习笔记之高质量C++/C编程指南

    高质量C++/C编程指南 http://man.lupaworld.com/content/develop/c&c++/c/c.htm 高质量C++/C编程指南(附录 C :C++/C 试题的 ...

  10. 谈C#中的Delegate

    引言 Delegate是Dotnet1.0的时候已经存在的特性了,但由于在实际工作中一直没有机会使用Delegate这个特性,所以一直没有对它作整理.这两天,我再度翻阅了一些关于Delegate的资料 ...