一、基础知识

box-shadow 属性向框添加一个或多个阴影。

语法

box-shadow: offset-x offset-y blur spread color inset;

box-shadow: X轴偏移量 Y轴偏移量 [阴影模糊半径] [阴影扩展] [阴影颜色] [投影方式];

单词解释:blur:模糊 spread:伸展 inset:内凹

参数解释:

offset-x:必需,取值正负都可。offset-x水平阴影的位置。

offset-y:必需,取值正负都可。offset-y垂直阴影的位置。

blur:可选,只能取正值。blur-radius阴影模糊半径,0即无模糊效果,值越大阴影边缘越模糊。

spread:可选,取值正负都可。spread代表阴影的周长向四周扩展的尺寸,正值,阴影扩大,负值阴影缩小。

color:可选。阴影的颜色。如果不设置,浏览器会取默认颜色,通常是黑色,但各浏览器默认颜色有差异,建议不要省略。可以是rgb(250,0,0),也可以是有透明值的rgba(250,0,0,0.5)

inset:可选。关键字,将外部投影(默认outset)改为内部投影。inset 内阴影,

Note:inset 可以写在参数的第一个或最后一个,其它位置是无效的。

浏览器支持

IE9+、Firefox 4、Chrome、Opera 以及 Safari 5.1.1 支持 box-shadow 属性。

为了兼容各主流浏览器并支持这些主浏览器的较低版本,基于主流浏览器上使用box-shadow属性时,我们需要将属性的名称写成

  -webkit-box-shadow:

  Firefox浏览器则需要写成-moz-box-shadow的形式

  欧朋浏览器  -o-box-shadow

  IE>9  -ms-box-shadow

注:此属性使用于盒模型 如(div,p,h1,h2,h3,h4,h5,h6等) 不是用来设置文字阴影   如果设置文字阴影请参考知识点:text-shadow(同理)。

二、使用

1、水平垂直偏移为0也可以有阴影

如果offset-x或offset-y值为0,则阴影在元素背后,此时给blur-radius值或spread值可以产生阴影效果。

例子:

第一个div通过设置blur-radius产生阴影效果。

第二个div通过设置spread正值产生阴影效果。

第三个div通过设置spread负值产生阴影效果。

但是有一点要注意:扩展阴影必须和阴影模糊半径配合使用。

我个人觉得应该是没有配合使用这一说,但不可能只设置扩展阴影,因为扩展阴影和阴影模糊的取值都可以为正。如果只有扩展阴影的话,会被浏览器当做模糊阴影来解析,所以也可以简单理解为“扩展阴影必须和阴影模糊半径配合使用”,如果只用扩展阴影,可以写成:box-shadow:0 0 0 1px;。

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7. div{
  8. width: 100px;
  9. height: 100px;
  10. margin:50px;
  11. border: 6px dotted pink;
  12. display: inline-block;
  13. font-weight: bold;
  14. text-align: center;
  15. line-height: 100px;
  16.  
  17. }
  18. .blur{
  19. box-shadow: 0 0 20px ;
  20. /*box-shadow: 0 0 20px green;*/ /*也可以自定义颜色*/
  21. }
  22. .spread-positive{
  23. box-shadow: 0 0 20px 5px ;
  24. /* box-shadow: 0 0 20px 5px green;*/ /*也可以自定义颜色*/
  25. }
  26. .spread-negative{
  27. box-shadow: 0 0 20px -5px ;
  28. /* box-shadow: 0 0 20px -5px green;*/ /*也可以自定义颜色*/
  29. }
  30. </style>
  31.  
  32. </head>
  33. <body>
  34. <div class="blur">1</div>
  35. <div class="spread-positive">2</div>
  36. <div class="spread-negative">3</div>
  37. </body>
  38. </html>

2、设置水平垂直偏移得到阴影效果

outset情况:水平垂直偏移为0,但是不设置blur和spread,看不到阴影,因为此时box-shadow的周长和border-box一样,所以可以通过设置偏移让阴影显示出来。

inset情况:水平垂直偏移为0,不设置blur和spread,同样看不到阴影,因为此时box-shadow的周长和padding-box一样,同样可通过设置偏移让阴影显示出来。

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7. div{
  8. width: 100px;
  9. height: 100px;
  10. margin:50px;
  11. border: 6px dotted pink;
  12. display: inline-block;
  13. font-weight: bold;
  14. text-align: center;
  15. line-height: 100px;
  16.  
  17. }
  18. .shadow0{box-shadow: 0 0;}
  19. .shadow1{box-shadow: 1px 1px;}
  20. .shadow10{box-shadow: 10px 10px;}
  21. .inset-shadow0{box-shadow: 0 0 inset;}
  22. .inset-shadow1{box-shadow: 1px 1px inset;}
  23. .inset-shadow10{box-shadow: 10px 10px inset;}
  24. </style>
  25.  
  26. </head>
  27. <body>
  28. <div class="shadow0">1</div>
  29. <div class="shadow1">2</div>
  30. <div class="shadow10">3</div>
  31. <div class="inset-shadow0">4</div>
  32. <div class="inset-shadow1">5</div>
  33. <div class="inset-shadow10">6</div>
  34. </body>
  35. </html>

3、投影方式

投影方式默认是outset,即外部投影,可设置inset让向内投影。

例子:第一个div默认outset,第二个设置inset,第三个同时设置两个阴影可以更好的看到outset和inset的关系,第四个div可以看出inset阴影在背景之上,内容之下。

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7. div{
  8. width: 100px;
  9. height: 100px;
  10. margin:50px;
  11. border: 6px dotted pink;
  12. display: inline-block;
  13. vertical-align: top;
  14. font-weight: bold;
  15. text-align: center;
  16.  
  17. }
  18.  
  19. .outset{
  20. box-shadow: 10px 10px teal;
  21. }
  22. .inset{
  23. box-shadow: 10px 10px teal inset;
  24. }
  25. .double{
  26. box-shadow: 10px 10px teal inset,10px 10px teal;
  27. }
  28. .bg{
  29. background-color: yellow;
  30. }
  31. </style>
  32.  
  33. </head>
  34. <body>
  35. <div class="outset">1</div>
  36. <div class="inset">2</div>
  37. <div class="double">3</div>
  38. <div class="inset bg">inset阴影在背景之上,内容之下</div>
  39. </body>
  40. </html>

4、如果元素同时指定border-radius属性,则阴影呈现相同的圆角。

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7. div{
  8. width: 100px;
  9. height: 100px;
  10. margin:50px;
  11. border: 6px dotted pink;
  12. display: inline-block;
  13. border-radius: 50px;
  14. vertical-align: top;
  15. font-weight: bold;
  16. text-align: center;
  17.  
  18. }
  19.  
  20. .shadow{
  21. box-shadow: 0 0 10px 10px green;
  22. }
  23. </style>
  24.  
  25. </head>
  26. <body>
  27. <div class="shadow"></div>
  28. </body>
  29. </html>

5、经典例子

w3c中的一个例子。http://www.w3.org/TR/css3-background/#the-box-shadow

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7.  
  8. .shadow{
  9. width: 100px; height: 100px;
  10. border: 12px solid blue; background-color: orange;
  11. border-top-left-radius: 50px 40px;
  12. border-bottom-right-radius: 50px 40px;
  13. box-shadow: 64px 64px 12px 40px rgba(0,0,0,0.4),
  14. 12px 12px 0px 8px rgba(0,0,0,0.4) inset;
  15. }
  16. </style>
  17.  
  18. </head>
  19. <body>
  20. <div class="shadow"></div>
  21. </body>
  22. </html>

可见:

  • border-radius会以相同的作用影响阴影外形
  • border-image,padding不会影响阴影的任何外形
  • 阴影box和box模型一样
  • 外阴影在对象背景之下,内阴影在背景之上。
  • 层次:内容>内阴影>背景图片>背景颜色>外阴影

6、多重阴影

这个效果在上面就看到了,现在再补充一些内容。

语法:可以设置任意多个阴影,用逗号隔开。

一个box有多重阴影时,需要注意顺序:多个阴影从上往下分布,第一个阴影在最顶层。

举例:单边阴影效果

先解释一下:可单独设置左边框的阴影,右边框的阴影,上边框的阴影,下边框的阴影,其实这样说也对,因为效果看起来就是这样,但根本原因是阴影在盒子后面,只是让阴影的位置发生了变化,其他3 个边的阴影还是存在的,只是被覆盖住了而已,所以,设置某个边的阴影是个很虚的东东了,哎,网上这种说法初看还让我略感困惑,所以我这里说是单边阴影效果,告诉大家只是一种效果,本质还是个box。

例子解释:给第一个div的上右下左border分别设置红橙黄绿,四种颜色,则red-shadow在最顶层,green-shadow在最底层,如下图左

给其加上blur模糊半径,效果更明显,如下图中,可见red-shadow的模糊半径不受干扰,因为在最顶层;接下来orange-shadow次之,被red-shadow的radius干扰;yellow-shadow被orange-shadow和red-shadow的radius干扰;同理green-shadow被它上面的所有shadow的radius干扰。

如果还是不太理解,那给red-shadow设置一个很大的radius,比如50,就可以看到非常明显的效果了,见下图右

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7. div{
  8. width: 100px;
  9. height: 100px;
  10. margin:50px;
  11. border: 6px dotted pink;
  12. display: inline-block;
  13. vertical-align: top;
  14. font-weight: bold;
  15. text-align: center;
  16.  
  17. }
  18. .shadow{
  19. box-shadow: 0 -5px red,
  20. 5px 0 orange,
  21. 0 5px yellow,
  22. -5px 0 green;
  23. }
  24. .blur-shadow{
  25. box-shadow: 0 -5px 5px red,
  26. 5px 0 5px orange,
  27. 0 5px 5px yellow,
  28. -5px 0 5px green;
  29. }
  30. .big-redShadow{
  31. box-shadow: 0 -5px 50px red,
  32. 5px 0 5px orange,
  33. 0 5px 5px yellow,
  34. -5px 0 5px green;
  35. }
  36. .big-dc{
  37. width: 100px;
  38. height: 100px;
  39. border:2px solid red;
  40. box-shadow: 0 0 0 2px orange,
  41. 0 0 0 4px yellow,
  42. 0 0 0 6px green,
  43. 0 0 0 8px #66CCCC,
  44. 0 0 0 10px blue,
  45. 0 0 0 12px #996699;
  46. }
  47. </style>
  48.  
  49. </head>
  50. <body>
  51. <div class="shadow">1</div>
  52. <div class="blur-shadow">2</div>
  53. <div class="big-redShadow">3</div>
  54. <div class="big-dc">4</div>
  55. </body>
  56. </html>

7、阴影和布局

阴影不影响布局, 但是可能会覆盖其他box或者其他box的阴影。

阴影不触发滚动条,也不增加滚动区域的大小。

所以布局时可忽略阴影。

8、spread妙用

用spread模拟实现border

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7. div{
  8. width: 100px;
  9. height: 100px;
  10. margin:50px;
  11. /* border: 6px dotted pink;*/
  12. display: inline-block;
  13. vertical-align: top;
  14. font-weight: bold;
  15. text-align: center;
  16. vertical-align: top;
  17. }
  18. .border{
  19. border:1px solid red;
  20. }
  21. .spread{
  22. box-shadow: 0 0 0 1px red;
  23. }
  24. .muli-border{
  25. box-shadow: 0 0 0 2px red,0 0 0 4px green,0 0 0 6px blue;
  26. }
  27. </style>
  28.  
  29. </head>
  30. <body>
  31. <div class="border">border</div>
  32. <div class="spread">box-shadow</div>
  33. <div class="muli-border">多重<br/>box-shadow</div>
  34. </body>
  35. </html>

用spread实现双色方括号:

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7. .decorator {
  8. width: 300px;
  9. height: 100px;
  10. padding: 30px;
  11. box-shadow: -30px -30px 0 -25px red,30px 30px 0 -25px green;
  12. }
  13. </style>
  14.  
  15. </head>
  16. <body>
  17. <div class="decorator">段落内容:用box-shadow模拟双色方括号box-shadow: -24px -24px 0 -20px red,24px 24px 0 -20px green; </div>
  18. </body>
  19. </html>

9、不均匀的阴影效果

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7. body {
  8. background: #eee;
  9. }
  10. .box {
  11. width:200px;
  12. height:100px;
  13. background:#FFF;
  14. margin:10px;
  15. line-height:100px;
  16. text-align:center;
  17. position: relative; /*为下面absolute定位做准备*/
  18. }
  19.  
  20. .one::before, .one::after {
  21. content: "";
  22. border:1px solid red;
  23. width: 50%;
  24. position: absolute;
  25. left: 10px;
  26. top: 80%;
  27. bottom: 15px;
  28. transform: rotate(-5deg); /*旋转*/
  29. box-shadow: 0 15px 10px #777; /*阴影*/
  30. }
  31. .one::after {
  32. transform: rotate(5deg); /*旋转*/
  33. right: 10px;
  34. left: auto;
  35. }
  36.  
  37. /* 最终效果 */
  38. .effect::before, .effect::after {
  39. content: "";
  40. width: 50%;
  41. position: absolute;
  42. left: 10px;
  43. top: 80%;
  44. bottom: 15px;
  45. transform: rotate(-5deg);
  46. box-shadow: 0 15px 10px #777;
  47. z-index: -1;
  48. }
  49. .effect::after {
  50. transform: rotate(5deg);
  51. right: 10px;
  52. left: auto;
  53. }
  54.  
  55. </style>
  56.  
  57. </head>
  58. <body>
  59. <div class="box one">step 0</div>
  60. <br /><br />
  61. <div class="box effect">step 1</div>
  62. </body>
  63. </html>

10、带透明效果

代码如下:

  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4. <meta charset="UTF-8">
  5. <title></title>
  6. <style>
  7. .embossed-heavy {
  8. width: 60px;
  9. height: 60px;
  10. background: red;
  11. border: 6px solid rgba(0,0,0,0.1);
  12. margin: 20px;
  13. box-shadow:
  14. inset 0 2px 3px rgba(255,255,255,0.3),
  15. inset 0 -2px 3px rgba(0,0,0,0.3),
  16. 0 1px 1px rgba(255,255,255,0.9);
  17. }
  18. .box {
  19. height: 34px;
  20. width: 80px;
  21. margin: 20px;
  22. text-align:center;
  23. /*background: #034a76; */
  24. border-radius: 40px;
  25. background: #034a76;
  26. box-shadow: 0 0 1px #fff, 0 0 3px #000, 0 0 3px #000,
  27. inset 0 1px #fff, inset 0 12px rgba(255,255,255,0.15),
  28. inset 0 4px 10px #cef,
  29. inset 0 22px 5px #0773b4,
  30. inset 0 -5px 10px #0df;
  31.  
  32. }
  33. </style>
  34.  
  35. </head>
  36. <body>
  37. <div class="embossed-heavy"></div>
  38. <div class="box ">按钮</div>
  39. </body>
  40. </html>

还有实现可以使用box-shadow实现一些类似渐变等效果。

三、资源链接

w3c box-shadow

box-shadow效果

http://elektronotdienst-nuernberg.de/bugs/box-shadow_inset.html

http://viget.com/uploads/file/boxshadows/

MDN box-shadow

自动生成阴影在线工具

mozilla交互工具可生成阴影

css3制作Drop shadow效果

 
 
 
 
 
 
参考地址:
http://www.cnblogs.com/starof/p/4424347.html
http://www.jianshu.com/p/1303b96661b9
 

box-shadow 用法总结的更多相关文章

  1. 如何设置box shadow的透明度

    (从已经死了一次又一次终于挂掉的百度空间人工抢救出来的,发表日期2014-04-24) 今天发现使用box-shadow属性,可以很好的给div添加阴影效果,但是添加的效果如果是: -moz-box- ...

  2. React Native 中的 Flex Box 的用法(水平布局、垂直布局、水平居中、垂直居中、居中布局)

     版权声明:本文仅供个人学习. CSS 中 Flex-Box 语法链接 http://www.ruanyifeng.com/blog/2015/07/flex-grammar.html Flex 是 ...

  3. Calibre LVS BOX 详细用法

    https://www.cnblogs.com/yeungchie/ LVS BOX的使用对于后端的团队协作起到非常便利的作用. 通过在lvs rules file添加BOX的相关语句可以达到这个目的 ...

  4. MFC中List box的用法

    首先在头文件中创建对象,CSGrid m_proViewList;//创建表头#pragma region 建立grid表的标题 m_proViewList.AppendColumn(_T(" ...

  5. 分享div、text、Box Shadow(阴影)演示及代码的页面

    附图: 直接上链接:www.css88.com/tool/css3Preview/Box-Shadow.html

  6. vagrant box各种命令汇总

    最近在研究laravel,中间用到了vagrant 虚拟机管理工具,学习一下他的命令 vagrant box命令 用于管理boxes的命令,比如添加.删除等等. 此命令的功能主要通过以下子命令完成: ...

  7. webAssmebly实现js数组排序 使用custom elements和Shadow DOM自定义组件

    直接上码了……………… .wat源码 (module (type $t0 (func (param i32 i32))) (type $t1 (func (result i32))) (type $t ...

  8. 来看看css3中的box-shadow

    不谈IE,只谈谈box-shadow的具体使用方法 语法: E {box-shadow: <length> <length> <length>?<length ...

  9. CSS 奇技淫巧十八招

    http://www.tuicool.com/articles/VZneI3   開始覺得自己會寫 CSS 也算有一段時間了,常常遇到一些非常實用的技巧不斷地反覆使用,但是我個人覺得對初學者來說很難從 ...

  10. 阅读MDN文档之StylingBoxes(五)

    目录 BoxModelRecap Box properties Overflow Background clip Background origin Outline Advanced box prop ...

随机推荐

  1. eclipse 创建c/c++ 工程

    新建 注意选择如下选项,c和c++ 都一样的 然后,编译运行 参考: https://blog.csdn.net/u013610133/article/details/72857870 https:/ ...

  2. 模板 - 字符串/数据结构 - 字典树/Trie

    使用静态数组的nxt指针的设计,大概比使用map作为nxt指针的设计要快1倍,但空间花费大概也大1倍.在数据量小的情况下,时间和空间效率都不及map<vector,int>.map< ...

  3. Java SpringBoot使用126邮箱发送html内容邮件,带附件

    package mail.demo; import org.junit.Test; import org.junit.runner.RunWith; import org.springframewor ...

  4. springboot项目获取resource下的文件

    package com.expr.exceldemo; import org.springframework.core.io.ClassPathResource; public class Test ...

  5. 11.linux dns服务器建立和安装apache

    dns服务器建立 1.安装bind建立dns服务器     yum install bind -y 2.安装好修改配置文件:vim /etc/named.conf 修改:      listen-on ...

  6. ubuntu之路——day8.5 学习率衰减learning rate decay

    在mini-batch梯度下降法中,我们曾经说过因为分割了baby batch,所以迭代是有波动而且不能够精确收敛于最小值的 因此如果我们将学习率α逐渐变小,就可以使得在学习率α较大的时候加快模型训练 ...

  7. T-MAX-冲刺总结

    T-MAX-冲刺总结 这个作业属于哪个课程 班级链接 这个作业要求在哪里 作业要求的链接 团队名称 T-MAX 这个作业的目标 冲刺总结 作业的正文 T-MAX-冲刺总结 其他参考文献 面向B站,百度 ...

  8. Tomcat 管理监控工具

    本文链接:https://blog.csdn.net/weixin_34364071/article/details/86753232 专注于Java领域优质技术号,欢迎关注 原创: 侯树成 Tomc ...

  9. spring boot修改代码后无需重启设置,在开发时实现热部署

    Spring Boot在开发时实现热部署(开发时修改文件保存后自动重启应用)(spring-boot-devtools) 热部署是什么 大家都知道在项目开发过程中,常常会改动页面数据或者修改数据结构, ...

  10. phpstorm 断点调试总是从index.php的第一行开始

    去掉勾选,重开phpstorm