浮動(dòng)的工作原理
10年積累的成都網(wǎng)站制作、成都網(wǎng)站建設(shè)經(jīng)驗(yàn),可以快速應(yīng)對(duì)客戶對(duì)網(wǎng)站的新想法和需求。提供各種問題對(duì)應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識(shí)你,你也不認(rèn)識(shí)我。但先網(wǎng)站設(shè)計(jì)后付款的網(wǎng)站建設(shè)流程,更有獲嘉免費(fèi)網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。
浮動(dòng)是讓某元素脫離文檔流,在浮動(dòng)框之前和之后的非定位元素會(huì)當(dāng)它不存在一樣,可能沿著它的另一側(cè)垂直流動(dòng),但都為其騰出空間,塊級(jí)元素也不例外(被浮動(dòng)元素占據(jù)了部分行空間的塊級(jí)元素,仍然被看作是占據(jù)了一整行,只不過是被浮動(dòng)元素占據(jù)的那部分空間無法利用罷了)。
浮動(dòng)的框可以向左或向右移動(dòng),直到它的外邊緣碰到包含框或另一個(gè)浮動(dòng)框的邊框?yàn)橹?;如果?dāng)前線上的水平空間不足,它將逐行向下移動(dòng),直到有空間為止(所以浮動(dòng)元素不會(huì)影響頁面上方布局)。任何元素都可以浮動(dòng),浮動(dòng)元素會(huì)生成一個(gè)塊級(jí)框(擁有塊級(jí)元素特性,但不占整行),而不論它本身是何種元素。
另外因?yàn)楦?dòng)元素脫離了文檔流,所有它無法為其文檔流中的父級(jí)元素?fù)纹鸶叨取?/p>
清除浮動(dòng)技巧
1、clear清除浮動(dòng)
left 在左側(cè)不允許浮動(dòng)元素。
right在右側(cè)不允許浮動(dòng)元素。
both在左右兩側(cè)均不允許浮動(dòng)元素。
none默認(rèn)值。允許浮動(dòng)元素出現(xiàn)在兩側(cè)。
在 CSS1 和CSS2中,這是通過自動(dòng)為清除元素(即設(shè)置了clear屬性的元素)增加上外邊距實(shí)現(xiàn)的。在CSS2.1中,會(huì)在元素上外邊距之上增加清除空間,而外邊距本身并不改變。不論哪一種改變,最終結(jié)果都一樣。例如:如果聲明為左邊清除,會(huì)使元素的上外邊框邊界剛好在左邊浮動(dòng)元素的下外邊距邊界之下。
要注意了,我們是通過在別的元素上清除浮動(dòng)來實(shí)現(xiàn)撐開高度的, 而不是在浮動(dòng)元素上。浮動(dòng)元素脫離了文檔流,就算為其加了清除空間,也影響不了父元素的高度,最多能讓其某側(cè)不允許其他浮動(dòng)元素。
clear 只能作用與塊級(jí)元素或浮動(dòng)元素,不過上面已經(jīng)說了作用于浮動(dòng)元素的弊端,所以一般都是使用塊級(jí)元素。
全瀏覽器通用的clearfix方案,使用偽元素清除浮動(dòng)【推薦】
// 引入了zoom以支持IE6/7
// 同時(shí)加入:before以解決現(xiàn)代瀏覽器上邊距折疊的問題
.clearfix:before,
.clearfix:after {
display: table;
content: " ";
}
.clearfix:after {
clear: both;
}
.clearfix{
*zoom: 1;
}
另外:也可以在父級(jí)元素中增加一個(gè)專門清除浮動(dòng)的塊級(jí)元素。(不推薦)
2、BFC清除浮動(dòng)
BFC全稱是塊狀格式化上下文,它是按照塊級(jí)盒子布局的。我們了解他的特征、觸發(fā)方式、常見使用場(chǎng)景這些就夠了。
BFC的主要特征
BFC容器是一個(gè)隔離的容器,和其他元素互不干擾;所以我們可以用觸發(fā)兩個(gè)元素的BFC來解決垂直邊距折疊問題。
BFC可以包含浮動(dòng);通常用來解決浮動(dòng)父元素高度坍塌的問題。
其中,BFC清除浮動(dòng)就是用的“包含浮動(dòng)”這條特性。
那么,怎樣才能觸發(fā)BFC呢?
BFC的觸發(fā)方式
我們可以給父元素添加以下屬性來觸發(fā)BFC:
float為left | right
overflow為hidden | auto | scorll
display為table-cell | table-caption | inline-block | flex | inline-flex
position為absolute | fixed
參考文獻(xiàn):http://www.jianshu.com/p/09bd5873bed4
https://www.w3.org/TR/2008/REC-CSS2-20080411/visuren.html#propdef-float
PS:如果對(duì)你有幫助,就順手點(diǎn)個(gè)贊吧~