CSS3实现多重边框的方法总结

时间:2021-05-08

方法1:div嵌套实现多重边框。

效果图:

html代码

XML/HTML Code复制内容到剪贴板
  • <divid="outer">
  • <divid="inner">div嵌套实现多重边框</div>
  • </div>
  • css代码

    CSS Code复制内容到剪贴板
  • #outer{
  • width:100px;
  • height:100px;
  • background-color:bisque;
  • border:10pxsolidbrown;
  • position:relative;
  • }
  • #inner{
  • width:84px;
  • height:84px;
  • border:8pxsolidblue;
  • }
  • 缺点:可能无法修改结构或修改html结构成本高;多个div都设置圆角时,边框之间不能完全贴合。圆角多边框效果图:

    方法2:使用outline+outline-offset实现多重边框。
    如果我们只需要绘制两层边框,使用outline也可以做到。outline是border外面的一层,和border原理一样。通过设定outline的样式可以为border外面再设定一层边框。
    但是需要注意的是,outline属性设定的边框不会随着内部元素边界样式的变化而变化。也就是说,如果元素边框带了圆角,那么outline绘制出的最外层边框仍然是矩形的。这是outline绘制边框的一个缺憾。
    效果图:

    html代码

    XML/HTML Code复制内容到剪贴板
  • <divid="outline">outlie实现多重边框</div>
  • css代码

    CSS Code复制内容到剪贴板
  • #outline{
  • width:84px;
  • height:84px;
  • border:8pxsolidblue;
  • outline:10pxsolidbrown;
  • outline-offset:0px;
  • margin:20px;
  • }
  • 优点:它跟边框类似,可以设置各种线型,比如虚线、实线。

    缺点:outline不影响布局,需使用margin给边框腾位置。以防被其它元素覆盖。如果容器本身有圆角的话,描边并不能完全贴合圆角,效果图如下:

    方法3:使用box-shadow 外投影实现多重边框。
    box-shadow属性可以为盒模型设定投影。但是其实它还有设定边框的功能。
    box-shadow可以传递五个参数,前两个参数表示投影的偏移量,第三个参数表示投影的模糊程度,第四个参数表示投影的扩张度,最后一个参数表示投影的颜色。然而我们平常很少用到第四个参数,在这里使用第四个参数,就可以让投影进行扩张,通过设定比较合适的值,就可以模拟出边框的效果了。
    同样,box-shadow属性可以传入多个阴影的列表,用“,”分割即可。因此,只要我们定义一个阴影列表,并且递增的增加其扩张度参数的取值,就可以绘制出多重边框的效果了。
    效果图:

    html代码

    XML/HTML Code复制内容到剪贴板
  • <divid="boxShadow">boxshadow实现多重边框(外投影)</div>
  • css代码

    CSS Code复制内容到剪贴板
  • #boxShadow{
  • margin:40px;
  • width:84px;
  • height:84px;
  • border:8pxsolidblue;
  • -webkit-border-radius:5px;
  • -moz-border-radius:5px;
  • border-radius:5px;
  • -webkit-box-shadow:00010pxbrown;
  • box-shadow:00010pxbrown;
  • }
  • 优点:多个圆角边框之间完全贴合;同时还可以接收一个列表,一次设置多个投影(即边框)。它的扩张效果是根据元素自己的形状来的,如果元素是矩形,它扩张开来就是一个更大的矩形;如果元素有圆角,它也会扩张出圆角。

    缺点:CSS3属性,兼容性不好;box-shadow也不影响布局的,如果这个元素和其它元素的相对位置关系很重要,需要以外边距等方式来为这些多出来的 “边框” 腾出位置,以防被其它元素覆盖。

    注意:使用内嵌投影(即box-shadow添加参数为inset,默认不设置时为外阴影)似乎是更好的选择。因为内嵌投影让投影出现在元素内部,设置内边距在元素的内部给多个边框腾位置,处理起来更容易一些。

    方法4:使用box-shadow 内投影实现多重边框。(推荐使用)

    效果图:

    html代码

    XML/HTML Code复制内容到剪贴板
  • <divid="moreboxShadow">boxshadow实现多重边框(内投影)</div>
  • css代码

    CSS Code复制内容到剪贴板
  • #moreboxShadow{
  • width:120px;
  • height:120px;
  • border:8pxsolidblue;
  • -webkit-box-shadow:inset00010pxbrown,inset00020pxyellow,inset00030pxgreen;
  • box-shadow:inset00010pxbrown,inset00020pxyellow,inset00030pxgreen;
  • padding:30px;
  • }
  • 优点:内嵌投影让投影出现在元素内部,设置内边距在元素的内部给多个边框腾位置,处理起来更容易一些。

    缺点:CSS3属性,兼容性不好

    声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

    相关文章