详解CSS3的box-shadow属性制作边框阴影效果的方法


Posted in HTML / CSS onMay 10, 2016

效果演示:
详解CSS3的box-shadow属性制作边框阴影效果的方法

box-shadow向框添加一个或多个阴影。IE9+、Firefox 4、Chrome、Opera 以及 Safari 5.1.1 支持 box-shadow 属性。
语法:
代码如下:

CSS Code复制内容到剪贴板
  1. box-shadow: h-shadow v-shadow blur spread color inset;  

h-shadow,v-shadow必须。水平,垂直阴影的位置。允许赋值。blur可选,模糊距离。spread可选,阴影的尺寸。color可选,阴影的颜色。inset可选,将外部阴影(outset)改为内部阴影。
来看几个简单的范例:

XML/HTML Code复制内容到剪贴板
  1. <body>  
  2.  <div class="box">  
  3.   <span class="caption">A</span>  
  4.  </div>  
  5.     
  6.  <div class="box">  
  7.   <span class="caption">B</span>  
  8.  </div>  
  9.     
  10.  <div class="box">  
  11.   <span class="caption">C</span>  
  12.  </div>  
  13.     
  14.  <div class="box">  
  15.   <span class="caption">D</span>  
  16.  </div>  
  17.     
  18.  <div class="box">  
  19.   <span class="caption">E</span>  
  20.  </div>  
  21.     
  22.  <div class="box">  
  23.   <span class="caption">F</span>  
  24.  </div>  
  25.     
  26.  <div class="box">  
  27.   <span class="caption">G</span>  
  28.  </div>  
  29.     
  30.  <div class="box">  
  31.   <span class="caption">H</span>  
  32.  </div>  
  33. </body>  

先将它们简单的设定一下样式:

CSS Code复制内容到剪贴板
  1. .box {   
  2.  background-color#fff;   
  3.  border3px solid #ccc;   
  4.  floatleft;   
  5.  margin20px 40px 0 0;   
  6.  height65px;   
  7.  width160px;   
  8.  text-aligncenter;   
  9. }   
  10. .caption {   
  11.  font-size20px;   
  12.  positionrelative;   
  13.  top20px;   
  14. }  

接着就一一来练习一下各种参数的使用方式。基本上使用 box-shadow 时最少得要提供 h-shadow 及 v-shadow 两个参数:

CSS Code复制内容到剪贴板
  1. .box:nth-child(1) {   
  2.  -webkit-box-shadow: 3px 3px #f3d42e;   
  3.  -moz-box-shadow: 3px 3px #f3d42e;   
  4.  box-shadow: 3px 3px #f3d42e;   
  5. }  

若位移距离为正值时就是往右或往下偏移;反之则往左或往上
详解CSS3的box-shadow属性制作边框阴影效果的方法

再加上 5px 的模糊半径:

CSS Code复制内容到剪贴板
  1. .box:nth-child(2) {   
  2.  -webkit-box-shadow: 3px 3px 5px #f3d42e;   
  3.  -moz-box-shadow: 3px 3px 5px #f3d42e;   
  4.  box-shadow: 3px 3px 5px #f3d42e;   
  5. }  

详解CSS3的box-shadow属性制作边框阴影效果的方法

扩散距离会加强实际的阴影的范围:

CSS Code复制内容到剪贴板
  1. .box:nth-child(3) {   
  2.  -webkit-box-shadow: 3px 3px 0 5px #f3d42e;   
  3.  -moz-box-shadow: 3px 3px 0 5px #f3d42e;   
  4.  box-shadow: 3px 3px 0 5px #f3d42e;   
  5. }  

位移的距离会在加上扩散距离,所以若值为负的会减少阴影的范围
详解CSS3的box-shadow属性制作边框阴影效果的方法

扩散出来的部份也会套上模糊的效果:

CSS Code复制内容到剪贴板
  1. .box:nth-child(4) {   
  2.  -webkit-box-shadow: 3px 3px 5px 5px #f3d42e;   
  3.  -moz-box-shadow: 3px 3px 5px 5px #f3d42e;   
  4.  box-shadow: 3px 3px 5px 5px #f3d42e;   
  5. }  

详解CSS3的box-shadow属性制作边框阴影效果的方法

如果没有设定位移距离的话,那么模糊的效果就会直接从区块周围露出:

CSS Code复制内容到剪贴板
  1. .box:nth-child(5) {   
  2.  -webkit-box-shadow: 0 0 15px #f3d42e;   
  3.  -moz-box-shadow: 0 0 15px #f3d42e;   
  4.  box-shadow: 0 0 15px #f3d42e;   
  5. }  

详解CSS3的box-shadow属性制作边框阴影效果的方法

再加上扩散距离:

CSS Code复制内容到剪贴板
  1. .box:nth-child(6) {   
  2.  -webkit-box-shadow: 0 0 15px 5px #f3d42e;   
  3.  -moz-box-shadow: 0 0 15px 5px #f3d42e;   
  4.  box-shadow: 0 0 15px 5px #f3d42e;   
  5. }  

详解CSS3的box-shadow属性制作边框阴影效果的方法

另外,若在使用时加上 inset 参数的话,则原本显示在区块外的阴影效果就会变成是内阴影的效果了:

CSS Code复制内容到剪贴板
  1. .box:nth-child(7) {   
  2.  -webkit-box-shadow: 3px 3px #f3d42e inset;   
  3.  -moz-box-shadow: 3px 3px #f3d42e inset;   
  4.  box-shadow: 3px 3px #f3d42e inset;   
  5. }  

有仔细注意到吗?本来位移距离为正值时就是往右或往下偏移,但因为加上 inset 参数,所以效果就反过来了:
详解CSS3的box-shadow属性制作边框阴影效果的方法

加上模糊半径及扩散距离:

CSS Code复制内容到剪贴板
  1. .box:nth-child(8) {   
  2.  -webkit-box-shadow: 3px 3px 5px 5px #f3d42e inset;   
  3.  -moz-box-shadow: 3px 3px 5px 5px #f3d42e inset;   
  4.  box-shadow: 3px 3px 5px 5px #f3d42e inset;   
  5. }  

详解CSS3的box-shadow属性制作边框阴影效果的方法

在元素上加了多组阴影设定的话:

CSS Code复制内容到剪贴板
  1. .box:nth-child(9) {   
  2.  -webkit-box-shadow: 13px 13px #f3d42e, -10px 10px #33d42e, -5px -10px #ff0d2d10px -8px #034d5e;   
  3.  -moz-box-shadow: 13px 13px #f3d42e, -10px 10px #33d42e, -5px -10px #ff0d2d10px -8px #034d5e;   
  4.  box-shadow: 13px 13px #f3d42e, -10px 10px #33d42e, -5px -10px #ff0d2d10px -8px #034d5e;   
  5. }   

阴影的阶层关系是越先设定的阶层会越高~
详解CSS3的box-shadow属性制作边框阴影效果的方法

当熟悉 box-shadow 的用法时,就能很简单又快速的将各种元素加上更有设计感的边框效果唷!

HTML / CSS 相关文章推荐
基于DOM+CSS3实现OrgChart组织结构图插件
Mar 02 HTML / CSS
CSS3实现时间轴效果
Jul 11 HTML / CSS
css3+伪元素实现鼠标移入时下划线向两边展开的效果
Apr 25 HTML / CSS
基于CSS3 animation动画属性实现轮播图效果
Sep 12 HTML / CSS
HTML5探秘:用requestAnimationFrame优化Web动画
Jun 03 HTML / CSS
HTML5实时语音通话聊天MP3压缩传输3KB每秒
Aug 28 HTML / CSS
HTML5 创建canvas元素示例代码
Jun 04 HTML / CSS
HTML5 Canvas绘制圆点虚线实例
Jan 01 HTML / CSS
简单整理HTML5的基本特性和语法
Feb 18 HTML / CSS
HTML5 body设置全屏背景图片的示例代码
Dec 08 HTML / CSS
css实现两栏布局,左侧固定宽,右侧自适应的多种方法
Aug 07 HTML / CSS
css让页脚保持在底部位置的四种方案
Jul 23 HTML / CSS
解决CSS3的opacity属性带来的层叠顺序问题
May 09 #HTML / CSS
详解CSS3的opacity属性设置透明效果的用法
May 09 #HTML / CSS
CSS3中使用RGBa来调节透明度的教程
May 09 #HTML / CSS
使用CSS3编写灰阶滤镜来制作黑白照片效果的方法
May 09 #HTML / CSS
CSS超出文本指定宽度用省略号代替和文本不换行
May 05 #HTML / CSS
CSS3实现曲线阴影和翘边阴影
May 03 #HTML / CSS
CSS3让登陆面板3D旋转起来
May 03 #HTML / CSS
You might like
?繁体转换的class
2006/10/09 PHP
兼容PHP5的PHP目录管理函数库
2008/07/10 PHP
PHP实现扎金花游戏之大小比赛的方法
2015/03/10 PHP
IE8 下的Js错误HTML Parsing Error...
2009/08/14 Javascript
关于图片按比例自适应缩放的js代码
2011/10/30 Javascript
input标签内容改变的触发事件介绍
2014/06/18 Javascript
正则表达式优化JSON字符串的技巧
2015/12/24 Javascript
jQuery实现点击某个div打开层,点击其他div关闭层实例分析(阻止冒泡)
2016/11/18 Javascript
jquery-mobile基础属性与用法详解
2016/11/23 Javascript
JS匿名函数类生成方式实例分析
2016/11/26 Javascript
js中的eval()函数把含有转义字符的字符串转换成Object对象的方法
2016/12/02 Javascript
浅谈JavaScript的计时器对象
2016/12/26 Javascript
jQuery实现标签页效果实战(4)
2017/02/08 Javascript
Node.js中的http请求客户端示例(request client)
2017/05/04 Javascript
关于vue-router的那些事儿
2018/05/23 Javascript
微信小程序template模板与component组件的区别和使用详解
2019/05/22 Javascript
Vue.js下拉菜单组件使用方法详解
2019/10/19 Javascript
Python ValueError: invalid literal for int() with base 10 实用解决方法
2015/06/21 Python
举例讲解Linux系统下Python调用系统Shell的方法
2015/11/07 Python
python绘制简单折线图代码示例
2017/12/19 Python
python操作oracle的完整教程分享
2018/01/30 Python
python unittest实现api自动化测试
2018/04/04 Python
python scipy求解非线性方程的方法(fsolve/root)
2018/11/12 Python
python中的TCP(传输控制协议)用法实例分析
2019/11/15 Python
python给图像加上mask,并提取mask区域实例
2020/01/19 Python
Pytorch中的自动求梯度机制和Variable类实例
2020/02/29 Python
Python编程快速上手——strip()函数的正则表达式实现方法分析
2020/02/29 Python
python def 定义函数,调用函数方式
2020/06/02 Python
英国经济型酒店品牌:Travelodge
2019/12/17 全球购物
毕业生找工作推荐信
2013/11/21 职场文书
机械专业应届生求职信
2013/12/12 职场文书
大学军训自我鉴定
2013/12/15 职场文书
社区文艺活动方案
2014/08/19 职场文书
销售辞职信范文
2015/03/02 职场文书
结婚典礼致辞
2015/07/28 职场文书
写作技巧:优秀文案必备的3种结构
2019/08/19 职场文书