详解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仿造window7的开始菜单
Jun 17 HTML / CSS
表单button的outline在firefox浏览器下的问题
Dec 24 HTML / CSS
基于CSS3特效之动画:animation的应用
May 09 HTML / CSS
html5实现完美兼容各大浏览器的播放器
Dec 26 HTML / CSS
实例讲解HTML5的meta标签的一些应用
Dec 08 HTML / CSS
HTML5中的进度条progress元素简介及兼容性处理
Jun 02 HTML / CSS
HTML5 客户端数据库简易使用:IndexedDB
Dec 19 HTML / CSS
使用layui框架实现点击左侧导航切换右侧内容且右侧选项卡跟随变化的效果
Nov 10 HTML / CSS
CSS3 天气图标动画效果
Apr 06 HTML / CSS
HTTP中的Content-type详解
Jan 18 HTML / CSS
css样式important规则的正确使用方式
Jun 10 HTML / CSS
CSS 鼠标选中文字后改变背景色的实现代码
May 21 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 和 MySQL 基础教程(三)
2006/10/09 PHP
ThinkPHP 在阿里云上的nginx.config配置实例详解
2017/10/11 PHP
PHP实现字符串翻转功能的方法【递归与循环算法】
2017/11/03 PHP
用JavaScript和注册表脚本实现右键收藏Web页选中文本
2007/01/28 Javascript
Javascript 实现TreeView CheckBox全选效果
2010/01/11 Javascript
jquery插件开发之实现google+圈子选择功能
2014/03/10 Javascript
AngularJS  双向数据绑定详解简单实例
2016/10/20 Javascript
JS 插件dropload下拉刷新、上拉加载使用小结
2017/04/13 Javascript
jQuery回调方法使用示例
2017/06/26 jQuery
JavaScript之filter_动力节点Java学院整理
2017/06/28 Javascript
Vue中组件之间数据的传递的示例代码
2017/09/08 Javascript
详解vuex commit保存数据技巧
2018/12/25 Javascript
解决layui的input独占一行的问题
2019/09/10 Javascript
20多个小事例带你重温ES10新特性(小结)
2019/09/29 Javascript
Element el-button 按钮组件的使用详解
2021/02/01 Javascript
用python删除java文件头上版权信息的方法
2014/07/31 Python
Python 序列化 pickle/cPickle模块使用介绍
2014/11/30 Python
在Python的setuptools框架下生成egg的教程
2015/04/13 Python
python通过邮件服务器端口发送邮件的方法
2015/04/30 Python
python类:class创建、数据方法属性及访问控制详解
2016/07/25 Python
Django 添加静态文件的两种实现方法(必看篇)
2017/07/14 Python
详解python的ORM中Pony用法
2018/02/09 Python
Python3模拟curl发送post请求操作示例
2019/05/03 Python
Python for循环及基础用法详解
2019/11/08 Python
基于TensorFlow常量、序列以及随机值生成实例
2020/01/04 Python
pytorch 修改预训练model实例
2020/01/18 Python
HTML5资源预加载(Link prefetch)详细介绍(给你的网页加速)
2014/05/07 HTML / CSS
Html5实现移动端、PC端 刮刮卡效果
2016/06/30 HTML / CSS
C面试题
2015/10/08 面试题
北京天润融通.net面试题笔试题
2012/02/20 面试题
无工作经验者个人求职信范文
2013/12/22 职场文书
自主实习接收函
2014/01/13 职场文书
致跳远运动员加油稿
2014/02/11 职场文书
预防艾滋病宣传活动总结
2015/05/09 职场文书
小公司融资,商业计划书的8切记
2019/07/15 职场文书
box-shadow单边阴影的实现
2023/05/21 HTML / CSS