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中的box-flex弹性盒属性布局
Jun 09 HTML / CSS
CSS3模拟动画下拉菜单效果
Apr 12 HTML / CSS
css3使用animation属性实现炫酷效果(推荐)
Feb 04 HTML / CSS
HTML5 用动画的表现形式装载图像
Mar 08 HTML / CSS
HTML5中Canvas与SVG的画图原理比较
Jan 16 HTML / CSS
分享全球十款超强HTML5开发工具
May 14 HTML / CSS
HTML5+CSS3实现拖放(Drag and Drop)示例
Jul 07 HTML / CSS
深入探究HTML5的History API
Jul 09 HTML / CSS
HTML5中的进度条progress元素简介及兼容性处理
Jun 02 HTML / CSS
CSS预处理框架——Stylus
Apr 21 HTML / CSS
小程序实现悬浮按钮的全过程记录
Oct 16 HTML / CSS
CSS三大特性继承性、层叠性和优先级详解
Jan 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
Linux编译升级php的详细方法
2013/11/04 PHP
php实现12306火车票余票查询和价格查询(12306火车票查询)
2014/01/14 PHP
PHP网页游戏学习之Xnova(ogame)源码解读(四)
2014/06/23 PHP
通过实例解析PHP数据类型转换方法
2020/07/11 PHP
document.compatMode介绍
2009/05/21 Javascript
提高网站性能之 如何对待JavaScript
2009/10/31 Javascript
用JavaScript对JSON进行模式匹配 (Part 2 - 实现)
2010/07/17 Javascript
DD_belatedPNG,IE6下PNG透明解决方案(国外)
2010/12/06 Javascript
js自定义事件代码说明
2011/01/31 Javascript
jQuery 1.7.2中getAll方法的疑惑分析
2012/05/23 Javascript
javascript函数声明和函数表达式区别分析
2014/12/02 Javascript
jQuery.Highcharts.js绘制柱状图饼状图曲线图
2015/03/14 Javascript
在JavaScript中处理字符串之link()方法的使用
2015/06/08 Javascript
浅谈Nodejs观察者模式
2015/10/13 NodeJs
Bootstrap CSS布局之表单
2016/12/17 Javascript
jquery.cookie.js的介绍与使用方法
2017/02/09 Javascript
如何构建一个Vue插件并生成npm包
2020/10/26 Javascript
浅谈python中的数字类型与处理工具
2017/08/02 Python
对python中的xlsxwriter库简单分析
2018/05/04 Python
win10下tensorflow和matplotlib安装教程
2018/09/19 Python
Python 3 实现定义跨模块的全局变量和使用教程
2019/07/07 Python
Django实现web端tailf日志文件功能及实例详解
2019/07/28 Python
python3 map函数和filter函数详解
2019/08/26 Python
使用pytorch实现可视化中间层的结果
2019/12/30 Python
大女孩胸罩:Big Girls Bras
2016/12/15 全球购物
Tommy Hilfiger澳洲官网:美国高端休闲领导品牌
2020/12/16 全球购物
写一个用矩形法求定积分的通用函数
2012/11/08 面试题
《挑山工》的教学反思
2014/02/16 职场文书
企业管理毕业生求职信范文
2014/03/07 职场文书
铁路安全事故反思
2014/04/26 职场文书
中学优秀班主任事迹材料
2014/05/01 职场文书
“向国旗敬礼”活动策划方案(4篇)
2014/09/27 职场文书
刘胡兰观后感
2015/06/16 职场文书
来探秘“德国中小企业”的成功之道
2019/07/26 职场文书
vue实现水波涟漪效果的点击反馈指令
2021/05/31 Vue.js
单机多实例部署 MySQL8.0.20
2022/05/15 MySQL