CSS3实现曲线阴影和翘边阴影


Posted in HTML / CSS onMay 03, 2016

本文实例为大家分享了CSS3实现曲线阴影和翘边阴影的效果,原来不用ps技术也可以实现阴影效果,很棒的效果,供大家参考,具体内容如下

效果图如下:

CSS3实现曲线阴影和翘边阴影

index.html

XML/HTML Code复制内容到剪贴板
  1. <!DOCTYPE html>     
  2. <html lang="en">     
  3. <head>     
  4.     <meta charset="UTF-8">     
  5.     <title>CSS3实现曲线阴影和翘边阴影</title>     
  6.     <style>     
  7.         /*源于imooc的学习*/     
  8.         body {     
  9.             font-family: "微软雅黑", "Microsoft YaHei";     
  10.             font-size: 20px;     
  11.         }     
  12.         body, ul, li, h1 {     
  13.             padding: 0;     
  14.             margin: 0;     
  15.         }     
  16.         ul {     
  17.             list-style: none outside none;     
  18.         }     
  19.         .wrap {     
  20.             width: 70%;     
  21.             height: 200px;     
  22.             margin: 50px auto;     
  23.             background-color: #fff;     
  24.         }     
  25.         .wrap h1 {     
  26.             font-size: 40px;     
  27.             text-align: center;     
  28.             line-height: 200px;     
  29.         }     
  30.      
  31.         /**     
  32.         * box-shadow     
  33.         * 功能:添加一个或多个阴影     
  34.         * 语法:box-shadow: h-shadow v-shadow blur spread color inset;     
  35.         * 参数:     
  36.         *      h-shadow(必需):水平阴影的位置。允许负值。     
  37.         *      v-shadow(必需):垂直阴影的位置。允许负值。     
  38.         *      blur(可选):模糊程度,值越大越模糊。     
  39.         *      spread(可选):阴影的尺寸。一般不推荐设置。     
  40.         *      color(可选):阴影的颜色。请参阅CSS颜色值。     
  41.         *      inset(可选):将外部阴影(outset)改为内部阴影。     
  42.         * 浏览器兼容:     
  43.         *      IE9+、Firefox 4、Chrome、Opera以及Safari 5.1.1支持box-shadow属性。     
  44.         */     
  45.         .effect {     
  46.             position: relative;     
  47.             /*box-shadow: h-shadow v-shadow blur color [inset];*/     
  48.             -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3), 0 0 40px rgba(0, 0, 0, 0.1) inset;     
  49.             -moz-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3), 0 0 40px rgba(0, 0, 0, 0.1) inset;     
  50.             -o-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3), 0 0 40px rgba(0, 0, 0, 0.1) inset;     
  51.             box-shadow: 0 1px 4px rgba(0, 0, 0, 0.3), 0 0 40px rgba(0, 0, 0, 0.1) inset;     
  52.         }     
  53.         /**     
  54.         * :after选择器:在被选元素的内容后面插入内容     
  55.         * :before选择器:在备选元素额内容后面插入内容     
  56.         * 说明:需要使用content属性来指定要插入的内容     
  57.         * 浏览器兼容:     
  58.         *      对于IE8及更早版本的:after,必须声明<!DOCTYPE>。     
  59.         *     
  60.         * content属性用于定义元素之前或之后放置的生成内容。默认地,这往往是行内内容,不过该内容创建的     
  61.         * 框类型可以用属性display控制。     
  62.         */     
  63.         .effect::after,.effect::before {     
  64.             content: '';     
  65.             background: #f00;     
  66.             position: absolute;     
  67.             top: 50%;     
  68.             bottom: 0;     
  69.             left: 20px;     
  70.             right: 20px;     
  71.             -webkit-box-shadow: 0 0 20px rgba(0,0,0,0.8);     
  72.             -moz-box-shadow: 0 0 20px rgba(0,0,0,0.8);     
  73.             -o-box-shadow: 0 0 20px rgba(0,0,0,0.8);     
  74.             box-shadow: 0 0 20px rgba(0,0,0,0.8);     
  75.      
  76.             border-radius: 100px/10px; /*水平半径/垂直半径*/     
  77.             z-index: -1;     
  78.         }     
  79.      
  80.         .box {     
  81.             width: 980px;     
  82.             height: auto;     
  83.             clear: both;     
  84.             overflow: hidden;     
  85.             margin: 20px auto;     
  86.         }     
  87.         .box li {     
  88.             width: 300px;     
  89.             height: 210px;     
  90.             float: left;     
  91.             margin: 20px 10px;     
  92.             border: 2px solid #EFEFEF;     
  93.      
  94.             -webkit-box-shadow: 0 1px 4px rgba(0,0,0,0.27), 0 0 60px rgba(0,0,0,0.1) inset;     
  95.             -moz-box-shadow: 0 1px 4px rgba(0,0,0,0.27), 0 0 60px rgba(0,0,0,0.1) inset;     
  96.             -o-box-shadow: 0 1px 4px rgba(0,0,0,0.27), 0 0 60px rgba(0,0,0,0.1) inset;     
  97.             box-shadow: 0 1px 4px rgba(0,0,0,0.27), 0 0 60px rgba(0,0,0,0.1) inset;     
  98.      
  99.             position: relative;     
  100.             background-color: #FFF;     
  101.         }     
  102.         .box li img {     
  103.             display: block;     
  104.             width: 290px;     
  105.             height: 200px;     
  106.             margin: 5px;     
  107.         }     
  108.      
  109.         .box li:before {     
  110.             content: '';     
  111.             position: absolute;     
  112.             width: 90%;     
  113.             height: 80%;     
  114.             left: 20px;     
  115.             bottom: 8px;     
  116.             /*background-color: #F00;*/     
  117.             background-color: transparent;     
  118.             box-shadow: 0 8px 20px rgba(0,0,0,0.6);     
  119.             -webkit-box-shadow: 0 8px 20px rgba(0,0,0,0.6);     
  120.             -moz-box-shadow: 0 8px 20px rgba(0,0,0,0.6);     
  121.             -o-box-shadow: 0 8px 20px rgba(0,0,0,0.6);     
  122.      
  123.             /**     
  124.             * transform     
  125.             * 功能:向元素应用2D或3D转换     
  126.             * 语法:transform: none|transform-functions     
  127.             * 参数:     
  128.             *      skew(x-angle,y-angle) 定义沿着X和Y轴的2D倾斜转换     
  129.             *      skewX(angle) 定义沿着X轴的2D倾斜转换。     
  130.             *      skewY(angle) 定义沿着y轴的2D倾斜转换。     
  131.             * 浏览器兼容:     
  132.             *      Internet Explorer 9支持替代的-ms-transform属性(仅适用于2D转换)     
  133.             *      Safari和Chrome支持替代的-webkit-transform属性(3D和2D转换)     
  134.             *      Opera只支持2D转换。     
  135.             */     
  136.             -webkit-transform: skewX(-11deg) rotate(-4deg);     
  137.             -moz-transform: skewX(-11deg) rotate(-4deg);     
  138.             -ms-transform: skewX(-11deg) rotate(-4deg);     
  139.             -o-transform: skewX(-11deg) rotate(-4deg);     
  140.             transform: skewX(-11deg) rotate(-4deg);     
  141.      
  142.             z-index: -1;     
  143.         }     
  144.      
  145.         .box li:after {     
  146.             content: '';     
  147.             position: absolute;     
  148.             width: 90%;     
  149.             height: 80%;     
  150.             right: 20px;     
  151.             bottom: 8px;     
  152.             background-color: transparent;     
  153.             box-shadow: 0 8px 20px rgba(0,0,0,0.6);     
  154.             -webkit-box-shadow: 0 8px 20px rgba(0,0,0,0.6);     
  155.             -moz-box-shadow: 0 8px 20px rgba(0,0,0,0.6);     
  156.             -o-box-shadow: 0 8px 20px rgba(0,0,0,0.6);     
  157.      
  158.             -webkit-transform: skewX(11deg) rotate(4deg);     
  159.             -moz-transform: skewX(11deg) rotate(4deg);     
  160.             -ms-transform: skewX(11deg) rotate(4deg);     
  161.             -o-transform: skewX(11deg) rotate(4deg);     
  162.             transform: skewX(11deg) rotate(4deg);     
  163.      
  164.             z-index: -1;     
  165.         }     
  166.     </style>     
  167. </head>     
  168. <body>     
  169.     <div class="wrap effect">     
  170.         <h1>Shadow Effect</h1>     
  171.     </div>     
  172.     <ul class="box">     
  173.         <li><img src="images/1.jpg" alt="1.jpg"></li>     
  174.         <li><img src="images/2.jpg" alt="2.jpg"></li>     
  175.         <li><img src="images/3.jpg" alt="3.jpg"></li>     
  176.     </ul>     
  177. </body>     
  178. </html>   

以上就是本文的全部内容,希望对大家的学习有所帮助。

HTML / CSS 相关文章推荐
CSS3画一个阴阳八卦图
Mar 09 HTML / CSS
CSS3教程(9):设置RGB颜色
Apr 02 HTML / CSS
CSS3 制作绽放的莲花采用效果叠加实现
Jan 31 HTML / CSS
css3实现的下拉菜单效果示例
Jan 22 HTML / CSS
CSS3实现菜单悬停效果
Nov 17 HTML / CSS
HTML5 Web Database 数据库的SQL语句的使用方法
Dec 09 HTML / CSS
HTML5 绘制图像(上)之:关于canvas元素引领下一代web页面的问题
Apr 24 HTML / CSS
HTML5 input placeholder 颜色修改示例
May 30 HTML / CSS
解析HTML5中的新功能本地存储localStorage
Mar 01 HTML / CSS
HTML5拖拽的简单实例
May 30 HTML / CSS
HTML5实现直播间评论滚动效果的代码
May 27 HTML / CSS
CSS 制作波浪效果的思路
May 18 HTML / CSS
CSS3让登陆面板3D旋转起来
May 03 #HTML / CSS
关于css兼容性问题及一些常见问题汇总
May 03 #HTML / CSS
CSS3 3D旋转rotate效果实例介绍
May 03 #HTML / CSS
CSS3过渡transition效果实例介绍
May 03 #HTML / CSS
浅析rem和em和px vh vw和% 移动端长度单位
Apr 28 #HTML / CSS
CSS3近阶段篇之酷炫的3D旋转透视
Apr 28 #HTML / CSS
CSS3的first-child选择器实战攻略
Apr 28 #HTML / CSS
You might like
实用函数8
2007/11/08 PHP
PHP Squid中可缓存的动态网页设计
2008/09/17 PHP
PHP使用正则表达式清除超链接文本
2013/11/12 PHP
CodeIgniter基于Email类发邮件的方法
2016/03/29 PHP
PHP魔术方法之__call与__callStatic使用方法
2017/07/23 PHP
PHP xpath()函数讲解
2019/02/11 PHP
Web版彷 Visual Studio 2003 颜色选择器
2007/01/09 Javascript
ie和firefox不兼容的解决方法集合
2009/04/28 Javascript
《JavaScript函数式编程》读后感
2015/08/07 Javascript
浅谈jquery的map()和each()方法
2016/06/12 Javascript
浅谈JS函数定义方式的区别
2016/10/30 Javascript
js获取指定时间的前几秒
2017/04/05 Javascript
Chrome调试折腾记之JS断点调试技巧
2017/09/11 Javascript
微信小程序开发的基本流程步骤
2019/01/31 Javascript
微信小程序自定义可滑动顶部TabBar选项卡实现页面切换功能示例
2019/05/14 Javascript
小程序实现锚点滑动效果
2019/09/23 Javascript
vue学习笔记之过滤器的基本使用方法实例分析
2020/02/01 Javascript
[02:30]DOTA2放量测试专访海涛:呼吁保护新手玩家
2013/08/26 DOTA
[02:09]2018DOTA2亚洲邀请赛TNC赛前采访
2018/04/04 DOTA
Python lambda和Python def区别分析
2014/11/30 Python
Python实现列表转换成字典数据结构的方法
2016/03/11 Python
对python sklearn one-hot编码详解
2018/07/10 Python
Tensorflow实现酸奶销量预测分析
2019/07/19 Python
Python with标签使用方法解析
2020/01/17 Python
Python操作Word批量生成合同的实现示例
2020/08/28 Python
Python的collections模块真的很好用
2021/03/01 Python
css3实现画半圆弧线的示例代码
2017/11/06 HTML / CSS
前端面试必备之html5的新特性
2017/09/05 HTML / CSS
抄作业检讨书
2014/02/17 职场文书
詹天佑教学反思
2014/04/30 职场文书
小学运动会加油稿
2015/07/22 职场文书
公司员工奖惩制度
2015/08/04 职场文书
乡镇干部学习心得体会
2016/01/23 职场文书
人生哲理妙语30条:淡写流年,笑过人生
2019/09/04 职场文书
mysql中数据库覆盖导入的几种方式总结
2022/03/25 MySQL