详解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新特性应用之过渡与动画
Jan 10 HTML / CSS
css3 条纹化和透明化表格Firefox下测试成功
Apr 15 HTML / CSS
css3通过scale()、rotate()实现放大、旋转
Mar 19 HTML / CSS
HTML5移动开发图片压缩上传功能
Nov 09 HTML / CSS
基于Html5实现的react拖拽排序组件示例
Aug 13 HTML / CSS
HTML5移动端开发中的Viewport标签及相关CSS用法解析
Apr 15 HTML / CSS
H5调用相机拍照并压缩图片的实例代码
Jul 20 HTML / CSS
有关HTML5页面在iPhoneX适配问题
Nov 13 HTML / CSS
Canvas图片分割效果的实现
Jul 29 HTML / CSS
HTML5表单验证特性(知识点小结)
Mar 10 HTML / CSS
video下autoplay属性无效的解决方法(添加muted属性)
May 19 HTML / CSS
完美实现CSS垂直居中的11种方法
Mar 27 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 将逗号、空格、回车分隔的字符串转换为数组的函数
2012/06/07 PHP
PHP中的生成XML文件的4种方法分享
2012/10/06 PHP
微信公众号判断用户是否已关注php代码解析
2016/06/24 PHP
mysql alter table命令修改表结构实例详解
2016/09/24 PHP
PHP基于面向对象封装的分页类示例
2019/03/15 PHP
Nigma vs Alliance BO5 第三场2.14
2021/03/10 DOTA
JQuery开发的数独游戏代码
2010/10/29 Javascript
根据邮箱的域名跳转到相应的登录页面的代码
2012/02/27 Javascript
js函数的延迟加载实现代码
2012/10/11 Javascript
web基于浏览器的本地存储方法应用
2012/11/27 Javascript
如何让页面加载完成后执行js
2013/06/26 Javascript
JS实现可拖曳、可关闭的弹窗效果
2015/09/26 Javascript
bootstrap输入框组使用方法
2017/02/07 Javascript
bootstrapvalidator之API学习教程
2017/06/29 Javascript
elementUI select组件value值注意事项详解
2019/05/29 Javascript
js全屏事件fullscreenchange 实现全屏、退出全屏操作
2019/09/17 Javascript
vue根据条件不同显示不同按钮的操作
2020/08/04 Javascript
ant design vue嵌套表格及表格内部编辑的用法说明
2020/10/28 Javascript
[52:52]DOTA2上海特级锦标赛C组资格赛#1 OG VS LGD第三局
2016/02/27 DOTA
Python搭建APNS苹果推送通知推送服务的相关模块使用指南
2016/06/02 Python
python使用SMTP发送qq或sina邮件
2017/10/21 Python
Django rest framework基本介绍与代码示例
2018/01/26 Python
Python实现数据可视化看如何监控你的爬虫状态【推荐】
2018/08/10 Python
python实现自动登录
2018/09/17 Python
基于html5 canvas做批改作业的小插件
2020/05/20 HTML / CSS
美国女孩服装购物网站:Justice
2017/03/04 全球购物
匡威德国官网:Converse德国
2019/01/26 全球购物
美国女士内衣在线折扣商店:One Hanes Place
2019/03/24 全球购物
如果NULL和0作为空指针常数是等价的,那我到底该用哪一个
2014/09/16 面试题
数控专业大学生的自我鉴定
2013/11/13 职场文书
大学生家政服务项目创业计划书
2014/01/30 职场文书
青春奉献演讲稿
2014/05/08 职场文书
扬尘污染防治方案
2014/06/15 职场文书
技术员岗位职责
2015/02/04 职场文书
高考学习决心书
2015/02/04 职场文书
2019暑假学生安全口号
2019/06/27 职场文书