Heim  >  Artikel  >  Web-Frontend  >  5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren

5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren

不言
不言Original
2018-05-09 11:36:571732Durchsuche

这篇文章主要介绍了关于CSS实现多重边框的5种方式 ,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下

简言

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

5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren

1 利用描边(outline)属性

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

1.1 核心代码

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

1.2 演示程序

5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren

演示程序

1.3 说明

  • 只能实现双重边框

  • 边框样式灵活,可以实现虚线等样式的边框

  • 描边在盒模型之外,会与外部元素发生重叠

2 利用额外的p

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

2.1 核心代码

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

2.2 演示程序

5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren

演示程序

2.3 说明

  • 兼容性好

  • 可以实现多重边框,虚线边框等样式

  • 需要额外的p元素,增加了代码复杂性

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 演示程序

5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren

演示程序

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 演示程序

5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren

演示程序

4.3 说明

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

5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren

其中包括四个角(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 演示程序

5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren

演示程序

5.3 说明

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

Wie das Strichattribut (outline) kann das box-shadow-Attribut umgebende Elemente überlappen. Legen Sie daher die Ränder des Elements entsprechend fest. box-shadowAllgemeine Kompatibilität.

Das Obige ist der gesamte Inhalt dieses Artikels. Weitere verwandte Inhalte finden Sie auf der chinesischen PHP-Website.


Das obige ist der detaillierte Inhalt von5 Möglichkeiten, mehrere Grenzen mit CSS zu implementieren. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn