CSS3实现多重边框的方法总结
方法1div嵌套实现多重边框。
效果图
html代码
- <div id="outer">
- <div id="inner">div嵌套实现多重边框</div>
- </div>
css代码
- #outer {
- width: 100px;
- height: 100px;
- background-color: bisque;
- border: 10px solid brown;
- position: relative;
- }
- #inner {
- width: 84px;
- height: 84px;
- border: 8px solid blue;
- }
- /#outer,
- #inner {
- -webkit-border-radius: 5px;
- -moz-border-radius: 5px;
- border-radius: 5px;
- }/
缺点可能无法修改结构或修改html结构成本高;多个div都设置圆角时,边框之间不能完全贴合。圆角多边框效果图
方法2使用outline+outline-offset实现多重边框。
如果我们只需要绘制两层边框,使用outline也可以做到。outline是border外面的一层,和border原理一样。通过设定outline的样式可以为border外面再设定一层边框。
需要注意的是,outline属性设定的边框不会随着内部元素边界样式的变化而变化。也就是说,如果元素边框带了圆角,那么outline绘制出的最外层边框仍然是矩形的。这是outline绘制边框的一个缺憾。
效果图
html代码
- <div id="outline">outlie实现多重边框</div>
css代码
- #outline {
- width: 84px;
- height: 84px;
- border: 8px solid blue;
- /-webkit-border-radius: 5px;
- -moz-border-radius: 5px;
- border-radius: 5px;/
- outline: 10px solid brown;
- outline-offset: 0px;
- /border和outline之间的距离/
- margin: 20px;
- /因为outline不影响布局,使用margin给边框腾位置/
- }
优点它跟边框类似,可以设置各种线型,比如虚线、实线。
缺点outline不影响布局,需使用margin给边框腾位置。以防被其它元素覆盖。如果容器本身有圆角的话,描边并不能完全贴合圆角,效果图如下
方法3使用box-shadow 外投影实现多重边框。
box-shadow属性可以为盒模型设定投影。其实它还有设定边框的功能。
box-shadow可以传递五个参数,前两个参数表示投影的偏移量,第三个参数表示投影的模糊程度,第四个参数表示投影的扩张度,一个参数表示投影的颜色。我们平常很少用到第四个参数,在这里使用第四个参数,就可以让投影进行扩张,通过设定比较合适的值,就可以模拟出边框的效果了。
同样,box-shadow属性可以传入多个阴影的列表,用“,”分割即可。,只要我们定义一个阴影列表,并且递增的增加其扩张度参数的取值,就可以绘制出多重边框的效果了。
效果图
html代码
- <div id="boxShadow">boxshadow实现多重边框(外投影)</div>
css代码
- #boxShadow {
- margin: 40px;
- /因为box-shadow不影响布局,使用margin给边框腾出位置/
- width: 84px;
- height: 84px;
- border: 8px solid blue;
- -webkit-border-radius: 5px;
- -moz-border-radius: 5px;
- border-radius: 5px;
- -webkit-box-shadow: 0 0 0 10px brown;
- box-shadow: 0 0 0 10px brown;
- /参数分别为水平偏移量、垂直偏移量、模糊距离、向外扩展距离和投影颜色/
- }
优点多个圆角边框之间完全贴合;还可以接收一个列表,一次设置多个投影(即边框)。它的扩张效果是根据元素自己的形状来的,如果元素是矩形,它扩张开来就是一个更大的矩形;如果元素有圆角,它也会扩张出圆角。
缺点CSS3属性,兼容性不好;box-shadow也不影响布局的,如果这个元素和其它元素的相对位置关系很重要,需要以外边距等方式来为这些多出来的 “边框” 腾出位置,以防被其它元素覆盖。
注意使用内嵌投影(即box-shadow添加参数为inset,默认不设置时为外阴影)似乎是更好的选择。因为内嵌投影让投影出现在元素内部,设置内边距在元素的内部给多个边框腾位置,处理起来更容易一些。
方法4使用box-shadow 内投影实现多重边框。(推荐使用)
效果图
html代码
- <div id="moreboxShadow">boxshadow实现多重边框(内投影)</div>
css代码
- /使用box-shadow一次性设置多个边框,并且使用内嵌投影/
- #moreboxShadow {
- width: 120px;
- height: 120px;
- border: 8px solid blue;
- /注意向外扩张的距离要每次累加;内嵌投影即添加参数为inset,该参数可选,当不设置时即为外投影/
- -webkit-box-shadow: inset 0 0 0 10px brown, inset 0 0 0 20px yellow, inset 0 0 0 30px green;
- box-shadow: inset 0 0 0 10px brown, inset 0 0 0 20px yellow, inset 0 0 0 30px green;
- padding: 30px;
- /设置内边距,为box-shadow添加的添加的边框疼位置,这样就不会影响元素之间的位置/
- }
优点内嵌投影让投影出现在元素内部,设置内边距在元素的内部给多个边框腾位置,处理起来更容易一些。
缺点CSS3属性,兼容性不好
长沙网站设计
- 如何进行东阳SEO关键词优化?
- 边坝哪有关键词排名优化:提升你的网站流量与
- 安国百度优化服务:提升您的在线可见性
- 阜康新手做SEO怎么做
- 山西seo网站排名关键词优化:提升您网站曝光率
- 临沂seo网站排名关键词优化:提高你的网站可见
- 广西SEO网站推广怎样付费比较合理
- 双辽SEO网站推广:提升你的网站可见性与流量
- 辽宁企业网站优化购买方式有哪些
- 提升宝清百度SEO排名的实用技巧与策略
- 静宁百度SEO排名:提升您网站曝光率的关键策略
- 彭州百度SEO排名的提升策略和实施指南
- 广南百度关键词SEO:提升网站排名的关键策略
- 辽宁关键词优化怎么做论坛营销
- 吉林百度seo排名如何做到让用户满意
- 内黄百度优化服务:提升在线可见性的关键