欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

CSS3實現(xiàn)多重邊框的方法總結(jié)

dobit   發(fā)布時間:2016-05-31 11:17:10   作者:佚名   我要評論
CSS3的box-shadow用來制作多重邊框真的比較給力,這也是本文CSS3實現(xiàn)多重邊框的方法總結(jié)的重點,不過在此之前我們還是先來看一下兼容性較好的傳統(tǒng)方式:

方法1:div嵌套實現(xiàn)多重邊框。

效果圖:
2016531111715888.jpg (135×136)

html代碼

XML/HTML Code復(fù)制內(nèi)容到剪貼板
  1. <div id="outer">  
  2.     <div id="inner">div嵌套實現(xiàn)多重邊框</div>  
  3. </div>  

css代碼

CSS Code復(fù)制內(nèi)容到剪貼板
  1. #outer {   
  2.     width100px;   
  3.     height100px;   
  4.     background-color: bisque;   
  5.     border10px solid brown;   
  6.     positionrelative;   
  7. }   
  8.     
  9. #inner {   
  10.     width84px;   
  11.     height84px;   
  12.     border8px solid blue;   
  13. }   
  14. /*#outer,  
  15. #inner {  
  16.     -webkit-border-radius: 5px;  
  17.     -moz-border-radius: 5px;  
  18.     border-radius: 5px;  
  19. }*/  

缺點:可能無法修改結(jié)構(gòu)或修改html結(jié)構(gòu)成本高;多個div都設(shè)置圓角時,邊框之間不能完全貼合。圓角多邊框效果圖:
2016531111759487.jpg (171×137)

方法2:使用outline+outline-offset實現(xiàn)多重邊框。
如果我們只需要繪制兩層邊框,使用outline也可以做到。outline是border外面的一層,和border原理一樣。通過設(shè)定outline的樣式可以為border外面再設(shè)定一層邊框。
但是需要注意的是,outline屬性設(shè)定的邊框不會隨著內(nèi)部元素邊界樣式的變化而變化。也就是說,如果元素邊框帶了圓角,那么outline繪制出的最外層邊框仍然是矩形的。這是outline繪制邊框的一個缺憾。
效果圖:
2016531111828724.jpg (137×132)

html代碼

XML/HTML Code復(fù)制內(nèi)容到剪貼板
  1. <div id="outline">outlie實現(xiàn)多重邊框</div>  

css代碼

CSS Code復(fù)制內(nèi)容到剪貼板
  1. #outline {   
  2.     width84px;   
  3.     height84px;   
  4.     border8px solid blue;   
  5.     /*-webkit-border-radius: 5px;  
  6.     -moz-border-radius: 5px;  
  7.     border-radius: 5px;*/  
  8.     outline10px solid brown;   
  9.     outline-offset: 0px;   
  10.     /*border和outline之間的距離*/  
  11.     margin20px;   
  12.     /*因為outline不影響布局,使用margin給邊框騰位置*/  
  13. }  

優(yōu)點:它跟邊框類似,可以設(shè)置各種線型,比如虛線、實線。

缺點:outline不影響布局,需使用margin給邊框騰位置。以防被其它元素覆蓋。如果容器本身有圓角的話,描邊并不能完全貼合圓角,效果圖如下:
2016531111901465.jpg (147×134)

方法3:使用box-shadow 外投影實現(xiàn)多重邊框。
box-shadow屬性可以為盒模型設(shè)定投影。但是其實它還有設(shè)定邊框的功能。
box-shadow可以傳遞五個參數(shù),前兩個參數(shù)表示投影的偏移量,第三個參數(shù)表示投影的模糊程度,第四個參數(shù)表示投影的擴張度,最后一個參數(shù)表示投影的顏色。然而我們平常很少用到第四個參數(shù),在這里使用第四個參數(shù),就可以讓投影進行擴張,通過設(shè)定比較合適的值,就可以模擬出邊框的效果了。
同樣,box-shadow屬性可以傳入多個陰影的列表,用“,”分割即可。因此,只要我們定義一個陰影列表,并且遞增的增加其擴張度參數(shù)的取值,就可以繪制出多重邊框的效果了。
效果圖:
2016531111924297.jpg (139×136)

html代碼

XML/HTML Code復(fù)制內(nèi)容到剪貼板
  1. <div id="boxShadow">boxshadow實現(xiàn)多重邊框(外投影)</div>  

css代碼

CSS Code復(fù)制內(nèi)容到剪貼板
  1. #boxShadow {   
  2.     margin40px;   
  3.     /*因為box-shadow不影響布局,使用margin給邊框騰出位置*/  
  4.     width84px;   
  5.     height84px;   
  6.     border8px solid blue;   
  7.     -webkit-border-radius: 5px;   
  8.     -moz-border-radius: 5px;   
  9.     border-radius: 5px;   
  10.     -webkit-box-shadow: 0 0 0 10px brown;   
  11.     box-shadow: 0 0 0 10px brown;   
  12.     /*參數(shù)分別為:水平偏移量、垂直偏移量、模糊距離、向外擴展距離和投影顏色*/  
  13. }  

優(yōu)點:多個圓角邊框之間完全貼合;同時還可以接收一個列表,一次設(shè)置多個投影(即邊框)。它的擴張效果是根據(jù)元素自己的形狀來的,如果元素是矩形,它擴張開來就是一個更大的矩形;如果元素有圓角,它也會擴張出圓角。

缺點:CSS3屬性,兼容性不好;box-shadow也不影響布局的,如果這個元素和其它元素的相對位置關(guān)系很重要,需要以外邊距等方式來為這些多出來的 “邊框” 騰出位置,以防被其它元素覆蓋。

注意:使用內(nèi)嵌投影(即box-shadow添加參數(shù)為inset,默認不設(shè)置時為外陰影)似乎是更好的選擇。因為內(nèi)嵌投影讓投影出現(xiàn)在元素內(nèi)部,設(shè)置內(nèi)邊距在元素的內(nèi)部給多個邊框騰位置,處理起來更容易一些。

方法4:使用box-shadow 內(nèi)投影實現(xiàn)多重邊框。(推薦使用)

效果圖:
2016531112012549.jpg (224×216)

html代碼

XML/HTML Code復(fù)制內(nèi)容到剪貼板
  1. <div id="moreboxShadow">boxshadow實現(xiàn)多重邊框(內(nèi)投影)</div>  

css代碼

CSS Code復(fù)制內(nèi)容到剪貼板
  1. /*使用box-shadow一次性設(shè)置多個邊框,并且使用內(nèi)嵌投影*/  
  2. #moreboxShadow {   
  3.     width120px;   
  4.     height120px;   
  5.     border8px solid blue;   
  6.     /*注意:向外擴張的距離要每次累加;內(nèi)嵌投影即添加參數(shù)為inset,該參數(shù)可選,當(dāng)不設(shè)置時即為外投影*/  
  7.     -webkit-box-shadow: inset 0 0 0 10px brown, inset 0 0 0 20px yellowinset 0 0 0 30px green;   
  8.     box-shadow: inset 0 0 0 10px brown, inset 0 0 0 20px yellowinset 0 0 0 30px green;   
  9.     padding30px;   
  10.     /*設(shè)置內(nèi)邊距,為box-shadow添加的添加的邊框疼位置,這樣就不會影響元素之間的位置*/  
  11. }  

優(yōu)點:內(nèi)嵌投影讓投影出現(xiàn)在元素內(nèi)部,設(shè)置內(nèi)邊距在元素的內(nèi)部給多個邊框騰位置,處理起來更容易一些。

缺點:CSS3屬性,兼容性不好

相關(guān)文章

  • CSS3 box-shadow屬性實例詳解

    這篇文章主要介紹了CSS3 box-shadow屬性實例詳解,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-06-19
  • CSS3陰影效果樣式庫box-shadows.css 53種

    box-shadows.css是一套集成了的CSS3陰影效果的CSS樣式庫,共有53種效果,只需要在元素上添加相應(yīng)的class類,既可以快速的生成相應(yīng)的陰影效果
    2018-06-13
  • css3 box-shadow陰影(外陰影與外發(fā)光)圖示講解

    這篇文章主要介紹了css3 box-shadow陰影(外陰影與外發(fā)光),通過五個測試通過圖片展示了陰影的不同位置不同效果,需要的朋友可以參考下
    2017-08-11
  • 詳解CSS3陰影 box-shadow的使用和技巧總結(jié)

    這篇文章主要介紹了詳解CSS3陰影 box-shadow的使用和技巧總結(jié) ,具有一定的參考價值,有需要的可以了解一下。
    2016-12-03
  • 詳解CSS3的box-shadow屬性制作邊框陰影效果的方法

    這篇文章主要介紹了CSS3的box-shadow屬性制作邊框陰影效果的方法,box-shadow屬性還是十分強大的,能設(shè)定陰影的水平或垂直位置,以及陰影的顏色和尺寸等,需要的朋友可以參考下
    2016-05-10
  • CSS3里box-shadow屬性的使用方法示例詳解

    這篇文章主要介紹了CSS3里box-shadow屬性的使用方法示例詳解,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧需要的朋友可以參
    2020-07-03

最新評論