V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
Can I use?
http://caniuse.com/
Less
http://lesscss.org
Cool Libraries
Bootstrap from Twitter
Jetstrap
iFat3
V2EX  ›  CSS

[基础] CSS 实现多重边框的 5 种方式

  •  
  •   iFat3 · 2018-05-04 23:33:24 +08:00 · 1098 次点击
    这是一个创建于 2421 天前的主题,其中的信息可能已经有所发展或是发生改变。

    简言

    目前最优雅地实现多重边框的方案是利用CSS3box-shadow属性,但如果要兼容老的浏览器,则需要选择其它的方案。本文简要地列举了几种多重边框的实现方案,大家可以根据项目实际及兼容性要求等情况,选择最适合的实现方案。

    CSS 多重边框

    1 利用描边(outline)属性

    方案 1 利用描边(outline)属性结合border属性实现双重边框。此方案实现简单,兼容性好,能兼容除IE6,7以外的浏览器。

    1.1 核心代码

    .borders {
      border: solid 6px #fff;
      outline: solid 6px #888;  
    }
    

    1.2 演示程序

    利用 outline 实现双重边框

    演示程序

    1.3 说明

    • 只能实现双重边框
    • 边框样式灵活,可以实现虚线等样式的边框
    • 描边在盒模型之外,会与外部元素发生重叠

    2 利用额外的 DIV

    方案 2 利用额外的 DIV 嵌套的方式实现多重边框。这也是唯一不存在兼容性问题的方案。

    2.1 核心代码

    .outer {
        border: solid 6px #888;
        background: #fff;
    }
    .inner {
        background: #222;
        margin: 6px;
    }
    

    2.2 演示程序

    利用额外的 DIV 嵌套实现双重边框

    演示程序

    2.3 说明

    • 兼容性好
    • 可以实现多重边框,虚线边框等样式
    • 需要额外的 DIV 元素,增加了代码复杂性

    3 利用伪元素

    方案 3 利用伪元素(:before)的方式实现双重边框。实现代码略复杂,属于 hack 的实现方式,不推荐。

    3.1 核心代码

    .borders {
        border: solid 6px #fff;
        position: relative;
    }
    .borders:before {
        content: "";
        position: absolute;
        top: -12px;
        left: -12px;
        right: -12px;
        bottom: -12px;
        border: solid 6px #888;
    }
    

    3.2 演示程序

    利用伪元素实现双重边框

    演示程序

    3.3 说明

    • IE6,7,8不兼容
    • :after也可以
    • 同时应用:before:after可以实现三重边框

    4 利用border-image属性

    方案 4 利用CSS3border-image属性实现多重边框。实现方法简单,但需要制做一个额外的边框图片,兼容性较差。

    4.1 核心代码

    .borders {
        border: solid 12px transparent;
        border-image: url('borders.jpg') 12 12 12 12 repeat;
    }
    

    4.2 演示程序

    利用 border-image 属性实现双重边框

    演示程序

    4.3 说明

    本例中,利用border-image-slice将边框图片分成如下图所示的 9 个区域:

    border-image-slice 示例图片

    其中包括四个角( 1,2,3,4 ),四条边( 5,6,7,8 )以及中间区域( 9 )。 repeat表示四条边都在相应的边框上重复的平铺。

    5 利用box-shadow属性

    方案 5 利用box-shadow属性实现多重边框。方案 5 是最简单,最直接的实现多重边框的方式。只有一行代码就可以实现多重边框效果。利用了阴影(box-shadow)实现边框多少有一些 hack 的味道。

    5.1 核心代码

    .borders {
        box-shadow: 0 0 0 6px #fff, 0 0 0 12px #888;
    }
    

    5.2 演示程序

    利用 box-shadow 属性实现多重边框

    演示程序

    5.3 说明

    为了用阴影模拟边框,本例中使用了两个阴影效果,设置偏移值和模糊值为0,并适当地设置阴影的尺寸,从而实现了双重边框的效果。因为一个阴影重叠在另一个阴影之上,第二个阴影的尺寸要设置成第一个阴影尺寸的两倍。关键部分是将模糊值设成 0,从而产生像边框一样的纯色阴影,看起来和边框一样。

    和描边(outline)属性一样,box-shadow属性可能会和周边元素发生重叠,因此要适当地设置元素的外边距。box-shadow兼容性一般。

    6 参考

    MDN border-image

    MDN box-shadow

    Multiple Borders with CSS

    CSS-tricks Multiple Borders

    7 结语

    本文简述了 5 种多重边框的实现方式,各有优缺点,大家要根据实际情况进行取舍。

    文中所述部分文字及代码汇编于网络。因时间不足,能力有限等原因,存在文字阐述不准及代码测试不足等诸多问题。

    1 条回复    2018-05-05 10:00:16 +08:00
    marcong95
        1
    marcong95  
       2018-05-05 10:00:16 +08:00
    都 8012 年了,还 IE678 ?
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   1063 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 19:59 · PVG 03:59 · LAX 11:59 · JFK 14:59
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.