详解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 相关文章推荐
CSS3 网页下拉菜单代码解释 中文翻译
Feb 27 HTML / CSS
HTML5拖放功能_动力节点Java学院整理
Jul 13 HTML / CSS
html5+css3进度条倒计时动画特效代码【推荐】
Mar 08 HTML / CSS
详解HTML5 Canvas绘制不规则图形时的非零环绕原则
Mar 21 HTML / CSS
Web前端页面跳转并取到值
Apr 24 HTML / CSS
HTML5拖放API实现拖放排序的实例代码
May 11 HTML / CSS
HTML5中input[type='date']自定义样式与日历校验功能的实现代码
Jul 11 HTML / CSS
canvas 橡皮筋式线条绘图应用方法
Feb 13 HTML / CSS
Html5 Canvas实现图片标记、缩放、移动和保存历史状态功能 (附转换公式)
Mar 18 HTML / CSS
CSS3实现指纹特效代码
Mar 17 HTML / CSS
HTML静态页面获取url参数和UserAgent的实现
Aug 05 HTML / CSS
HTML页面点击按钮关闭页面的多种方式
Dec 24 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
给初学PHP的5个入手程序
2006/11/23 PHP
mysql 中InnoDB和MyISAM的区别分析小结
2008/04/15 PHP
php 随机排序广告的实现代码
2011/05/09 PHP
Laravel jwt 多表(多用户端)验证隔离的实现
2019/12/18 PHP
EasyUI中datagrid在ie下reload失败解决方案
2015/03/09 Javascript
深入浅析JavaScript中的arguments对象(强力推荐)
2016/06/03 Javascript
js控件Kindeditor实现图片自动上传功能
2020/07/20 Javascript
BootStrap 图片样式、辅助类样式和CSS组件的实例详解
2017/01/20 Javascript
node.js的事件机制
2017/02/08 Javascript
webpack2.0搭建前端项目的教程详解
2017/04/05 Javascript
vue-router 导航钩子的具体使用方法
2017/08/31 Javascript
vue中的scope使用详解
2017/10/29 Javascript
浅谈React和Redux的连接react-redux
2017/12/04 Javascript
vue脚手架搭建过程图解
2018/06/06 Javascript
vue中子组件调用兄弟组件方法
2018/07/06 Javascript
200行HTML+JavaScript实现年会抽奖程序
2019/01/22 Javascript
nuxt框架中对vuex进行模块化设置的实现方法
2019/09/06 Javascript
JS函数基本定义与用法示例
2020/01/15 Javascript
详解Vue中的watch和computed
2020/11/09 Javascript
JavaScript实现点击图片换背景
2020/11/20 Javascript
python中元类用法实例
2014/10/10 Python
教你用Python脚本快速为iOS10生成图标和截屏
2016/09/22 Python
python中实现控制小数点位数的方法
2019/01/24 Python
Python Matplotlib实现三维数据的散点图绘制
2019/03/19 Python
python pptx复制指定页的ppt教程
2020/02/14 Python
keras中epoch,batch,loss,val_loss用法说明
2020/07/02 Python
详解python百行有效代码实现汉诺塔小游戏(简约版)
2020/10/30 Python
美国专业消费电子及摄影器材网站:B&H Photo Video
2019/12/18 全球购物
嘻哈珠宝品牌:KRKC&CO
2020/10/19 全球购物
医院检讨书范文
2014/02/01 职场文书
工程建设实施方案
2014/03/14 职场文书
导游词300字
2015/02/13 职场文书
金正昆讲礼仪观后感
2015/06/11 职场文书
2016年小学感恩节活动总结
2016/04/01 职场文书
教你如何使用Python Tkinter库制作记事本
2021/06/10 Python
Java框架入门之简单介绍SpringBoot框架
2021/06/18 Java/Android