在css3中,BFC的中文意思為“區塊格式化上下文”,是Web頁面的可視CSS渲染的一部分,是區塊盒子的佈局過程發生的區域,也是浮動元素與其他元素交互的區域。簡單來說,BFC就是頁面上的一個隔離的獨立容器,容器裡面的子元素不會影響外面的元素。 BFC的作用:1、解決外邊距折疊問題;2、BFC的區域不會與浮動的元素區域重疊,可建立CSS中常用的兩欄佈局;3、清除元素內部的浮動。
本教學操作環境:windows7系統、CSS3&&HTML5版、Dell G3電腦。
官方定義:BFC(Block Formatting Context)區塊格式化上下文, 是Web頁面的視覺CSS渲染的一部分,是區塊盒子的佈局過程發生的區域,也是浮動元素與其他元素互動的區域。
說人話:BFC就是頁面上的一個隔離的獨立容器,容器裡面的子元素不會影響到外面的元素。 我們常常使用到BFC,只不過不知道它是BFC而已。
常用的方式有以下幾種:
none
,指定float為left或right就可以建立BFC)position
為absolute
或fixed
)#看吧,是不是常常在程式碼中用到上邊列舉的屬性,你在不知不覺中就開啟了BFC,只是你不知道它是BFC而已。
1、解決外邊距折疊問題
外邊距折疊(Margin collapsing)也只會發生在屬於同一BFC的區塊級元素之間。
html:
<div class="div1"></div> <div class="div2"></div>
css:
.div1 { width: 100px; height: 100px; background-color: green; margin-bottom: 10px; } .div2 { width: 100px; height: 100px; background-color: red; margin-top: 20px; }
對第一個div的margin-bottom設定為10px,第二個div的margin-top設定為20px,我們可以看到兩個盒子最終的邊距是20px,是兩者之中較大的一個。這就是外邊距重疊的問題。
為了解決這個問題,我們可以讓這兩個div分屬於不同的BFC,或是只要把其中一個div放到BFC中就可以。原因是:BFC就是頁面上的一個隔離的獨立容器,容器裡面的元素不會對外邊產生影響。
html:
<div class="wrapper"> <div class="div1"></div> </div> <div class="div2"></div>
css:
.wrapper{ /* 开启BFC */ overflow: hidden; } .div1 { width: 100px; height: 100px; background-color: green; margin-bottom: 10px; } .div2 { width: 100px; height: 100px; background-color: red; margin-top: 20px; }
現在的程式碼可以解決外邊距重疊的問題啦!但是注意,在我們這個案例中,雖然指定position屬性為absolute和fixed,或者float指定為left、right也可以創建BFC,但是這個元素會從當前文檔流中移除,不佔據頁面空間,並且可以和其它元素重疊。導致下邊的div會把上邊的div給覆蓋掉。
2、製作兩個欄位佈局
BFC的區域不會與浮動的元素區域重疊。
我們可以利用這個特性來創建CSS中常用的兩欄佈局(左邊寬度固定,右邊寬度自適應)。
HTML:
<div class="left"></div> <div class="right"></div>
CSS:
.left { width: 200px; height: 100px; background-color: green; float: left; } .right { height: 100px; background-color: red; overflow: hidden; /* 创建BFC */ }
效果如圖所示:
#另一個案例:
html:
<div class="father"> <div class="left"></div> <div class="right"> 哈哈哈哈哈哈啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊啊 </div> </div>
css:
.father { width: 200px; border: 5px solid blue; } .left { width: 50px; height: 50px; background-color: green; float: left; } .right { height: 100px; background-color: red; }
當在父元素中只設定一個盒子浮動,另一個不浮動時,會造成第二個盒子在第一個盒子的下方,被覆蓋掉一部分(但文字不會被覆蓋)。
效果如圖:
為第二個元素設定BFC:
.right { height: 100px; background-color: red; overflow: hidden; }
效果如圖:
3、清除元素内部的浮动
这里清除浮动的意思并不是清除你设置的元素的浮动属性,而是清除设置了浮动属性之后给别的元素带来的影响。例如我们给子元素设置浮动,那么父元素的高度就撑不开了。
BFC有一个特性:计算BFC的高度时,浮动元素也参与计算,利用这个特性可以清除浮动。
html:
<div class="div1"> <div class="son1">a</div> <div class="son2">b</div> </div>
css:
.div1 { width: 150px; border: 1px solid red; /*使用BFC来清除浮动*/ overflow: hidden; } .son1, .son2 { width: 100px; height: 100px; background-color: blue; float: left; } .son2 { background-color: greenyellow; }
(学习视频分享:web前端入门)
以上是css3中什麼是bfc的詳細內容。更多資訊請關注PHP中文網其他相關文章!