详解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 相关文章推荐
任意一块网页内容实现“活”的背景(目前火狐浏览器专有)
May 07 HTML / CSS
CSS3实现曲线阴影和翘边阴影
May 03 HTML / CSS
CSS3制作彩色进度条样式的代码示例分享
Jun 23 HTML / CSS
利用CSS3动画实现圆圈由小变大向外扩散的效果实例
Sep 10 HTML / CSS
CSS3中媒体查询结合rem布局适配手机屏幕
Jun 10 HTML / CSS
详解Html5 Canvas画线有毛边解决方法
Mar 01 HTML / CSS
自定义html标记替换html5新增元素
Oct 17 HTML / CSS
移动端解决悬浮层(悬浮header、footer)会遮挡住内容的3种方法
Mar 27 HTML / CSS
html5中的一些标签学习(心得)
Oct 18 HTML / CSS
html5关于外链嵌入页面通信问题(postMessage解决跨域通信)
Jul 20 HTML / CSS
如何使用amaze ui的分页样式封装一个通用的JS分页控件
Aug 21 HTML / CSS
通过feDisplacementMap和feImage实现水波特效
Apr 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和XSS跨站攻击的防范
2007/04/17 PHP
php函数实现判断是否移动端访问
2015/03/03 PHP
PHP在同一域名下两个不同的项目做独立登录机制详解
2017/09/22 PHP
laravel中的fillable和guarded属性详解
2019/10/23 PHP
在一个form用一个SUBMIT(或button)分别提交到两个处理表单页面的代码
2007/02/15 Javascript
Javascript中setTimeOut和setInterval的定时器用法
2015/06/12 Javascript
js实现仿阿里巴巴城市选择框效果实例
2015/06/24 Javascript
jQuery实现响应鼠标滚动的动感菜单效果
2015/09/21 Javascript
jquery插件bootstrapValidator表单验证详解
2016/12/15 Javascript
jQuery实现弹出窗口弹出div层的实例代码
2017/01/09 Javascript
将鼠标焦点定位到文本框最后(代码分享)
2017/01/11 Javascript
详解ElementUI之表单验证、数据绑定、路由跳转
2017/06/21 Javascript
Require.js的基本用法详解
2017/07/03 Javascript
Angularjs的启动过程分析
2017/07/18 Javascript
JavaScript编写棋盘覆盖代码详解
2017/08/28 Javascript
Vue 页面切换效果之 BubbleTransition(推荐)
2018/04/08 Javascript
JS立即执行函数功能与用法分析
2019/01/15 Javascript
[04:45]DOTA2上海特级锦标赛主赛事第四日RECAP
2016/03/06 DOTA
python 3.6 tkinter+urllib+json实现火车车次信息查询功能
2017/12/20 Python
python linecache 处理固定格式文本数据的方法
2019/01/08 Python
Python异常处理知识点总结
2019/02/18 Python
PyQt5实现从主窗口打开子窗口的方法
2019/06/19 Python
python Dijkstra算法实现最短路径问题的方法
2019/09/19 Python
python flask搭建web应用教程
2019/11/19 Python
Python实现钉钉订阅消息功能
2020/01/14 Python
Matplotlib中%matplotlib inline如何使用
2020/07/28 Python
2021年值得向Python开发者推荐的VS Code扩展插件
2021/01/25 Python
两种CSS3伪类选择器详细介绍
2013/12/24 HTML / CSS
Linux文件操作命令都有哪些
2016/07/23 面试题
社会公德演讲稿
2014/05/20 职场文书
2014领导班子正风肃纪思想汇报
2014/09/18 职场文书
群众路线教育实践活动民主生活会个人检查对照思想汇报
2014/10/04 职场文书
运动会广播稿200字
2014/10/18 职场文书
副校长2015年教育教学工作总结
2015/07/27 职场文书
新娘婚礼致辞
2015/07/27 职场文书
Android Rxjava3 使用场景详解
2022/04/07 Java/Android