CSS3阴影box-shadow功能的使用详解

这次给大家带来CSS3阴影box-shadow功能的使用详解,使用CSS3阴影box-shadow的注意事项有哪些,下面就是实战案例,一起来看一下。

text-shadow是给文本添加阴影效果,box-shadow是给元素块添加周边阴影效果。随着HTML5和CSS3的普及,这一特殊效果使用越来越普遍。

基本语法是{box-shadow:[inset] x-offset y-offset blur-radius spread-radiuscolor}

对象选择器 {box-shadow:[投影方式] X轴偏移量 Y轴偏移量阴影模糊半径 阴影扩展半径 阴影颜色}

box-shadow属性的参数设置取值:

阴影类型:此参数可选。如不设值,默认投影方式是外阴影;如取其唯一值“inset”,其投影为内阴影;

X-offset:阴影水平偏移量,其值可以是正负值。如果值为正值,则阴影在对象的右边,其值为负值时,阴影在对象的左边;

Y-offset:阴影垂直偏移量,其值也可以是正负值。如果为正值,阴影在对象的底部,其值为负值时,阴影在对象的顶部;

阴影模糊半径:此参数可选,,但其值只能是为正值,如果其值为0时,表示阴影不具有模糊效果,其值越大阴影的边缘就越模糊;

阴影扩展半径:此参数可选,其值可以是正负值,如果值为正,则整个阴影都延展扩大,反之值为负值时,则缩小;

阴影颜色:此参数可选。如不设定颜色,浏览器会取默认色,但各浏览器默认取色不一致,特别是在webkit内核下的safari和chrome浏览器下表现为透明色,在Firefox/Opera下表现为黑色(已验证),建议不要省略此参数。

浏览器的兼容:

CSS3阴影box-shadow功能的使用详解

为了兼容各主流浏览器并支持这些主流浏览器的较低版本,在基于Webkit的Chrome和Safari等浏览器上使用box-shadow属性时,我们需要将属性的名称写成-webkit-box-shadow的形式。Firefox浏览器则需要写成-moz-box-shadow的形式。

box-shadow{           //Firefox0-           -moz-box-shadow:投影方式 X轴偏移量 Y轴偏移量阴影模糊半径 阴影扩展半径 阴影颜色;           //Safariand Google chrome0-           -webkit-box-shadow:投影方式 X轴偏移量 Y轴偏移量阴影模糊半径 阴影扩展半径 阴影颜色;           //Firefox0+、 Google chrome 0+ 、 Oprea5+ and IE9             box-shadow:  投影方式 X轴偏移量 Y轴偏移量 阴影模糊半径 阴影扩展半径 阴影颜色;    }

注意:出于方便,后文的css属性有的地方只写了box-shadow属性,没有写-moz-和-webkit-前缀的形式,在使用中不要忘记加上。

为了更清楚的了解box-shadow的特征,做几个小测试,看效果:

 相关代码:

          CSS3属性:box-shadow测试        box-shadow-1{    -webkit-box-shadow: 3px 3px 3px;    -moz-box-shadow: 3px 3px 3px;    box-shadow: 3px 3px 3px;  }  box-shadow-2{    -webkit-box-shadow:0 0 10px #0CC;    -moz-box-shadow:0 0 10px #0CC;    box-shadow:0 0 10px #0CC;  }  box-shadow-3{    -webkit-box-shadow:0 0 10px rgba(0, 204, 204, 5);    -moz-box-shadow:0 0 10px rgba(0, 204, 204, 5);    box-shadow:0 0 10px rgba(0, 204, 204, 5);  }  box-shadow-4{    -webkit-box-shadow:0 0 10px 15px #0CC;    -moz-box-shadow:0 0 10px 15px #0CC;    box-shadow:0 0 10px 15px #0CC;  }  box-shadow-5{    -webkit-box-shadow:inset 0 0 10px #0CC;    -moz-box-shadow:inset 0 0 10px #0CC;    box-shadow:inset 0 0 10px #0CC;  }  box-shadow-6{      box-shadow:-10px 0 10px red, /*左边阴影*/      10px 0 10px yellow, /*右边阴影*/      0 -10px 10px blue, /*顶部阴影*/      0 10px 10px green; /*底边阴影*/  }  box-shadow-7{      box-shadow:0 0 10px 5px black,      0 0 10px 20px red;  }  box-shadow-8{      box-shadow:0 0 10px 20px red,      0 0 10px 5px black;  }  box-shadow-9{      box-shadow: 0 0 0 1px red;  }        obj{      width:100px;      height:100px;      margin:50px auto;      background:#eee;      }  outer{      width: 100px;      height: 100px;      border: 1px solid red;  }  inner{      width: 60px;      height: 60px;      background-color: red;      -webkit-box-shadow: 50px 50px blue;      -moz-box-shadow: 50px 50px blue;      box-shadow: 50px 50px blue;    }              

$(document)ready(function(){ if($browsermsie) { $('obj')boxShadow(-10,-10,5,"#0cc"); //obj元素使用了box-shadow } });

结论:

1)  从.box-shadow-1的效果可以得出不指定属性阴影颜色的情况下,阴影在webkit内核下的safari和chrome浏览器下表现为透明色,在Firefox/Opera下表现为黑色。

CSS3阴影box-shadow功能的使用详解

2)  从内外两个p块inner、outer的对比来看,所有支持box-shadow的主流浏览器都表现为:内层阴影撑破外层容器将整个阴影效果呈现出来。W3C标准用图示的方式对box-shadow的原理和表现进行了解读:

CSS3阴影box-shadow功能的使用详解

从图中我们可以了解到:圆角border-radius,阴影扩展半径、阴影模糊半径以及padding是如何影响对象阴影的:非零值的border-radius将会以相同的作用影响阴影的外形,但border-image不会影响对象阴影的任何外形;对象阴影同box模型的层次一样,外阴影会在对象背景之下,内阴影会在边框之下背景之上。我们知道,默认情形背景图片是在背景颜色之上的。所以整个层级是:边框>内阴影>背景图片>背景颜色>外阴影。

 3)  从. box-shadow-2到. box-shadow-5的效果,我们可以了解到box-shadow取值的作用。

. box-shadow-2是xy没有偏移,阴影大小10px,没有扩展半径,颜色#0CC即rgba(0, 204,204, 1),这里我们使用的是颜色HEX值;效果

CSS3阴影box-shadow功能的使用详解

而. box-shadow-3是在. box-shadow-2效果的基础上,应用了rgba颜色值,好处是给box-shadow阴影添加了alpha透明效果。效果:

CSS3阴影box-shadow功能的使用详解

. box-shadow-4在. box-shadow-2效果的基础上添加了阴影扩展半径15px。

CSS3阴影box-shadow功能的使用详解

. box-shadow-5在. box-shadow-2效果的基础上,将外阴影设为内阴影。

CSS3阴影box-shadow功能的使用详解

4). box-shadow-6一个元素使用了多个阴影,多个阴影之间用逗号分隔。给对象四边设置阴影效果,我们是通过改变x-offset和y-offset的正负值来实现,其中x-offset为负值时,生成左边阴影,为正值时生成右边阴影,y-offset为正值是生成底部阴影,为负值时生成顶部阴影。并且把模糊半径设置为0,如果不设置为0的话那么其他三边也将会有阴影。这点需要注意!

CSS3阴影box-shadow功能的使用详解

注意这样的写法是错误的:{box-shadow:-10px 0 10px red, box-shadow:10px 0 10px blue,box-shadow:0 -10px 10px yellow,box-shadow:0 10px 10px green} 

并且此处还涉及到一个多阴影的顺序问题。当给同一个元素使用多个阴影属性时,需要注意它的顺序,最先写的阴影将显示在最顶层,如. box-shadow-7设为不同的模糊值:

.box-shadow-7{         box-shadow:0 0 10px 5px black,         0 0 10px 20px red;}

将能看出层叠的顺序效果:

CSS3阴影box-shadow功能的使用详解

如果将两个阴影效果调一下,改为如下:

.box-shadow-8{         box-shadow:0 0 10px 20px red,         0 0 10px 5px black;}

将只显示红色的阴影效果,因为红色阴影层在上面,模糊半径大,将后面的黑色阴影完全遮挡。

CSS3阴影box-shadow功能的使用详解

得出的结论是:如果前面的阴影模糊值小于后面的阴影模糊值,那么前面的显示在后面之上,如果前面阴影的模糊值大于后面的阴影模糊值,那么前面的阴影将遮住后面的阴影效果。

4)  类border边框效果(只设置阴影扩展半径和阴影颜色)

.box-shadow-9呈现的效果,同boder:1px solid red相似,但box-shadow的效果与border效果在对象高度上有区别,正好要比border高度大一个扩展半径。而且阴影不影响页面的任何布局,这一点可以通过查看firebug下的layout图得以证实。

CSS3阴影box-shadow功能的使用详解

5)  在ie下模拟css3中的box-shadow阴影效果

方法一:可以使用IE的Shadow滤镜

基本语法:filter:progid:DXImageTransform.Microsoft.Shadow(color=’颜色值’, Direction=阴影角度(数值),Strength=阴影半径(数值));

注意:该滤镜必须配合background属性一起使用,否则该滤镜失效。

IE下模拟css3中的box-shadow(阴影)代码:

box-shadow{      filter: progid:DXImageTransformMicrosoftShadow(color='#969696',Direction=135, Strength=5);/*for ie6,7,8*/      background-color: #ccc;      -moz-box-shadow:2px 2px 5px #969696;/*firefox*/      -webkit-box-shadow:2px 2px 5px #969696;/*webkit*/      box-shadow:2px 2px 5px #969696;/*opera或ie9*/  }

在六一儿童节的专题中,我是这么处理的:

liblk-item{           width:423px;           height:229px;           float:left;           padding:8px;           margin:2px 18px 13px 21px;           display:inline;           border:1px solid #d3c998;           border-radius:2px;           filter:progid:DXImageTransformMicrosoftShadow(color='#d3c998', Direction=135,Strength=5);/*for ie6,7,8*/           background-color: #fff;           -moz-box-shadow:2px 2px 5px#d3c998;/*firefox*/           -webkit-box-shadow:2px 2px 5px#d3c998;/*webkit*/           box-shadow:2px 2px 5px #d3c998;/*opera或ie9*/    }

方法二:有些js和.htc的hack文件可以实现IE中的阴影效果。

ie-css3.htc是一个可以让IE浏览器支持部份CSS3属性的htc文件,不只是box-shadow,它还可以让你的IE浏览器支持圆角属性border-radius和文字阴影属性text-shadow。

它的使用方法是:下载它并放到你的服务器目录

在你的

里面写入下面的代码:

这个脚本的缺点是IE只支持一部分的box-shadow值。需要注意:

当你使用了这个htc文件后,你的CSS里面,只要写有box-shadow, -moz-box-shadow或-webkit-box-shadow的任何一种,IE就会渲染。

当使用了这个htc文件后,你不能这样写box-shadow: 0 0 10px red; 而应该是box-shadow: 0px 0px 10px red; 否则IE中会失效。

不支持RGBA值中的alpha透明度。

不支持inset内阴影。

不支持阴影扩展。

阴影在IE中只会显示为黑色,不管你设置成其它什么颜色。

方法三:使用jQuery的插件jquery.boxshadow.js,插件的下载地址是http://www.hintzmann.dk/testcenter/js/jquery/boxshadow/jquery.boxshadow.js

使用方法很简单,将该文件和jquery版本库引入head标签,插入以下js效果代码:

            $(document)ready(function(){     if($browsermsie) {       $('obj')boxShadow(-10,-10,5,"#0cc"); //obj元素使用了box-shadow     }   });  

注意:js中可以使用:obj.style.webkitBoxShadow=值(字符串);obj.style.MozBoxShadow=值(字符串);obj.style.boxShadow=值(字符串);

补充知识:CSS3的属性

border-top-left-radius:[ | ] [ | ]?

默认值:0

取值:

用长度值设置对象的左上角(top-left)圆角半径长度。不允许负值

 用百分比设置对象的左上角(top-left)圆角半径长度。不允许负值

说明:

设置或检索对象的左上角圆角边框。提供2个参数,2个参数以空格分隔,每个参数允许设置1个参数值,第1个参数表示水平半径,第2个参数表示垂直半径,如第2个参数省略,则默认等于第1个参数。 如设置border-top-left-radius:5px10px;表示top-left这个角的水平圆角半径为5px,垂直圆角半径为10px。对应的脚本特性为borderTopLeftRadius。

相信看了本文案例你已经掌握了方法,更多精彩请关注创想鸟其它相关文章!

推荐阅读:

三种绝对定位元素的水平垂直居中的办法

width:100%;与width:auto的使用区别

水平垂直居中的方法

以上就是CSS3阴影box-shadow功能的使用详解的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1609744.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 00:57:12
下一篇 2025年12月23日 00:14:57

相关推荐

  • css3中量级单位的使用区别

    这次给大家带来css3中量级单位的使用区别,css3中量级单位使用的注意事项有哪些,下面就是实战案例,一起来看一下。 px:绝对单位,页面按精确像素展示 em:相对单位,基准点为父节点字体的大小,如果自身定义了font-size按自身来计算(浏览器默认字体是16px),整个页面内1em不是一个固定的…

    好文分享 2025年12月24日
    000
  • CSS控制文字的换行与裁剪

    这次给大家带来CSS控制文字的换行与裁剪,CSS控制文字换行与裁剪的注意事项有哪些,下面就是实战案例,一起来看一下。 关于换行、裁剪的一些CSS属性 word-wrap: normal | break-word normal 正常换行,内容可以撑破容器,例如长单词或者长数字的情况break-word…

    2025年12月24日
    000
  • css中的margin属性详解

    这次给大家带来css中的margin属性详解,使用css中margin的注意事项有哪些,下面就是实战案例,一起来看一下。 之前我一直认为margin属性是一个非常简单的属性,但是最近做项目时遇到了一些问题,才发现margin属性还是有一些“坑”的,下面我会介绍margin的基本知识以及那些“坑”。这…

    2025年12月24日 好文分享
    000
  • css的多种书写方式

    这次给大家带来css的多种书写方式,css书写方式的注意事项有哪些,下面就是实战案例,一起来看一下。 优先级: 外部样式 优先级,即:同名的选择器右边的会覆盖左边 1.内部样式表 CSS Code复制内容到剪贴板                 /*内部样式表,一般用于覆盖公用样式*/       …

    好文分享 2025年12月24日
    000
  • CSS实现3D按钮效果

    这次给大家带来CSS实现3D按钮效果,CSS实现3D按钮效果的注意事项有哪些,下面就是实战案例,一起来看一下。 css巧妙利用了box-shadow来实现3D物体的立体感,当按钮按下的时候再去修改box-shadow和top值。 让人感觉有一种按钮被按下的感觉。css代码非常少,如下所示 a.css…

    2025年12月24日
    000
  • css中Float属性详解

    这次给大家带来css中Float属性详解,使用css中Float属性的注意事项有哪些,下面就是实战案例,一起来看一下。 一、Float的特性 1. 应用于文字围绕图片 2. 创建一个块级框 3. 多列浮动布局 4. 浮动元素的宽度、高度自适应,但可以设置其值。 二、核心解决的问题 文字围绕图片:im…

    2025年12月24日 好文分享
    000
  • Css3的之形状总结

    这次给大家带来Css3的之形状总结,使用Css3形状的注意事项有哪些,下面就是实战案例,一起来看一下。 一、自适应椭圆  border-radius特性: 可以单独指定水平和垂直半径,并且值可以是百分比,用/(斜杠)分隔这两个值即可(可以实现自适应宽度椭圆)。 还可以单独指定四个角度不同的水平和垂直…

    2025年12月24日 好文分享
    000
  • CSS的居中布局总结

    这次给大家带来CSS的居中布局总结,CSS居中布局的注意事项有哪些,下面就是实战案例,一起来看一下。 先来说几种简单的、人畜无害的居中方法 1. 把margin设为auto 具体来说就是把要居中的元素的margin-left和margin-right都设为auto,此方法只能进行水平的居中,且对浮动…

    2025年12月24日 好文分享
    000
  • 在CSS边界线消失如何处理

    这次给大家带来在CSS边界线消失如何处理,处理在CSS边界线消失的注意事项有哪些,下面就是实战案例,一起来看一下。 先来看看下图,经常会在一些导航栏中见到,要求每行中最后一列的右边框消失,如何在所有浏览器中最便捷优雅的实现? 如果是不需要兼容 IE8- ,那么使用 CSS3 新增的选择器无疑是一种好…

    2025年12月24日
    000
  • CSS3的blur白边怎么去除

    这次给大家带来CSS3的blur白边怎么去除,去除CSS3的blur白边注意事项有哪些,下面就是实战案例,一起来看一下。 做一个登录页,全屏背景图毛玻璃效果,实现方法如下: HTML:                   var w = window.innerWidth || document.d…

    2025年12月24日 好文分享
    000
  • CSS3的box-sizing属性图文教程

    这次给大家带来CSS3的box-sizing属性图文教程,使用CSS3的box-sizing属性注意事项有哪些,下面就是实战案例,一起来看一下。 简介 box-sizing属性包括content-box(default),border-box,padding-box。      1、content-…

    2025年12月24日
    000
  • css中的float的图文详解

    这次给大家带来css中的float的图文详解,float的图文详解的注意事项有哪些,下面就是实战案例,一起来看一下。 float与margin 两个相邻的浮动元素,当第一个浮动元素(不论是左浮动还是右浮动)的宽度为100%时,第二个浮动元素会被挤到下面,通过添加负margin-right值(绝对值最…

    2025年12月24日
    000
  • CSS3的webkit-tap-highlight-color属性如何使用

    这次给大家带来CSS3的webkit-tap-highlight-color属性如何使用,使用CSS3的webkit-tap-highlight-color的注意事项有哪些,下面就是实战案例,一起来看一下。 -webkit-tap-highlight-color 这个属性只用于iOS (iPhone…

    好文分享 2025年12月24日
    000
  • CSS3做出响应式、可配置的抽奖转盘

    这次给大家带来CSS3做出响应式、可配置的抽奖转盘,CSS3做出响应式、可配置的抽奖转盘的注意事项有哪些,下面就是实战案例,一起来看一下。 源于前段时候微信小程序最初火爆公测时段,把以前用 Canvas 实现的大转盘抽奖移植成微信小程序,无奈当时小程序对 Canvas 支持不够完善,只好降低用 CS…

    2025年12月24日
    000
  • CSS3实现扇形动画菜单流程详解

    这次给大家带来CSS3实现扇形动画菜单流程详解,CSS3实现扇形动画菜单的注意事项有哪些,下面就是实战案例,一起来看一下。 原文章请点击这里 简化版完整实例 CSS3扇形动画菜单*{padding: 0; margin: 0;}body{background:#b1b1b1;margin:0px;p…

    2025年12月24日
    000
  • 动态加载css详解

    这次给大家带来动态加载css详解,动态加载css的注意事项有哪些,下面就是实战案例,一起来看一下。 一、方法引用来源和应用 此动态加载css方法 loadCss,剥离自Sea.js,并做了进一步的优化(优化代码后续会进行分析)。 因为公司项目需要用到懒加载来提高网站加载速度,所以将非首屏渲染必需的c…

    好文分享 2025年12月24日
    000
  • css3+js实现3D行星运转

    这次给大家带来css3+js实现3D行星运转,css3+js实现3D行星运转的注意事项有哪些,下面就是实战案例,一起来看一下。 HTML部分 这里用前三个类为x、y、z的p来画的每一个星球的x、y、z轴,然后这些星球之间是可以嵌套的,就是像上面的代码一样,里面的星球是外面星球的卫星。 css部分 .…

    2025年12月24日
    000
  • HTML5+CSS3加载进度条与下载进度条实现

    这次给大家带来HTML5+CSS3加载进度条与下载进度条实现,HTML5+CSS3加载进度条与下载进度条实现的注意事项有哪些,下面就是实战案例,一起来看一下。 效果图: 1、html结构: 0%  简单分析下: p.loadBar代表整个进度条 p.loadBar p 设置了圆角表框 ,p.load…

    2025年12月24日
    000
  • CSS3制作粉红色登录界面

    这次给大家带来CSS3制作粉红色登录界面,CSS3制作粉红色登录界面的注意事项有哪些,下面就是实战案例,一起来看一下。 心血来潮,想学学 material design 的设计风格,就尝试完成了一个登录页面制作. 这是整体效果. 感觉还不错吧,结尾会附上代码 在编写的过程中,没有使用任何图片或者字体…

    2025年12月24日 好文分享
    000
  • css3视觉特效的实现

    这次给大家带来css3视觉特效的实现,实现css3视觉特效的注意事项有哪些,下面就是实战案例,一起来看一下。 一、单侧阴影 1、box-shadow属性的应用,格式:h-shadow v-shadow blur spread color inset属性取值介绍 h-sahdow:水平阴影的位置,允许…

    2025年12月24日 好文分享
    000

发表回复

登录后才能评论
关注微信