首先要知道,div是塊級元素,在頁面中獨佔一行,自上而下排列,也就是傳說中的流。如下圖:
可以看出,即使div1的寬度很小,頁面中一行可以容下div1和div2,div2也不會排在div1後邊,因為div元素是獨佔一行的。
注意,以上這些理論,是指標準流中的div。無論多麼複雜的布局,其基本出發點均是:「如何在一行顯示多個div元素」。
顯然標準流已經無法滿足需求,這就要用到浮動。 浮動可以理解為讓某個div元素脫離標準流,漂浮在標準流之上,和標準流不是乙個層次。
例如,假設上圖中的div2浮動,那麼它將脫離標準流,但div1、div3、div4仍然在標準流當中,所以div3會自動向上移動,佔據div2的位置,重新組成乙個流。如圖:
從圖中可以看出,由於對div2設定浮動,因此它不再屬於標準流,div3自動上移頂替div2的位置,div1、div3、div4依次排列,成為乙個新的流。又因為浮動是漂浮在標準流之上的,因此div2擋住了一部分div3,div3看起來變「矮」了。
這裡div2用的是左浮動(float:left;),可以理解為漂浮起來後靠左排列,右浮動(float:right;)當然就是靠右排列。這裡的靠左、靠右是說頁面的左、右邊緣。
如果我們把div2採用右浮動,會是如下效果:
此時div2靠頁面右邊緣排列,不再遮擋div3,讀者可以清晰的看到上面所講的div1、div3、div4組成的流。
目前為止我們只浮動了乙個div元素(div2),如果浮動多個div呢?
下面我們把div2和div3都加上左浮動,效果如圖:
同理,由於div2、div3浮動,它們不再屬於標準流,因此div4會自動上移,與div1組成乙個「新」標準流,而浮動是漂浮在標準流之上,因此div2又擋住了div4。
當同時對div2、div3設定浮動之後,div3會跟隨在div2之後,不知道讀者有沒有發現,一直到現在,div2在每個例子中都是浮動的,但並沒有跟隨到div1之後。因此,我們可以得出乙個重要結論:
假如某個div元素a是浮動的,如果a元素上乙個元素也是浮動的,那麼a元素會跟隨在上乙個元素的後邊(如果一行放不下這兩個元素,那麼a元素會被擠到下一行);如果a元素上乙個元素是標準流中的元素,那麼a的相對垂直位置不會改變,也就是說a的頂部總是和上乙個元素的底部對齊。
為了幫助讀者理解,再舉幾個例子。
假如我們把div2、div3、div4都設定成左浮動,效果如下:
根據上邊的結論:先從div4開始分析,它發現上邊的元素div3是浮動的,所以div4會跟隨在div3之後;div3發現上邊的元素div2也 是浮動的,所以div3會跟隨在div2之後;而div2發現上邊的元素div1是標準流中的元素,因此div2的相對垂直位置不變,頂部仍然和div1 元素的底部對齊。由於是左浮動,左邊靠近頁面邊緣,所以左邊是前,因此div2在最左邊。
假如把div2、div3、div4都設定成右浮動,效果如下:
道理和左浮動基本一樣,只不過需要注意一下前後對應關係。由於是右浮動,因此右邊靠近頁面邊緣,所以右邊是前,因此div2在最右邊。
假如我們只把div2、div4左浮動,效果圖如下:
依然是根據結論,div2、div4浮動,脫離了標準流,因此div3將會自動上移,與div1組成標準流。div2發現上乙個元素div1是標準 流中的元素,因此div2相對垂直位置不變,與div1底部對齊。div4發現上乙個元素div3是標準流中的元素,因此div4的頂部和div3的底部 對齊,並且總是成立的,因為從圖中可以看出,div3上移後,div4也跟著上移,div4總是保證自己的頂部和上乙個元素div3(標準流中的元素)的底部對齊。
至此,恭喜讀者已經掌握了新增浮動,但還有清除浮動,有上邊的基礎清除浮動非常容易理解。
經過上邊的學習,可以看出:元素浮動之前,也就是在標準流中,是豎向排列的,而浮動之後可以理解為橫向排列。
清除浮動可以理解為打破橫向排列。
清除浮動的關鍵字是clear,官方定義如下:
語法:定義非常容易理解,但是讀者實際使用時可能會發現不是這麼回事。clear : none | left | right | both
取值:none : 預設值。允許兩邊都可以有浮動物件
left : 不允許左邊有浮動物件
right : 不允許右邊有浮動物件
both : 不允許有浮動物件
定義沒有錯,只不過它描述的太模糊,讓我們不知所措。
根據上邊的基礎,假如頁面中只有兩個元素div1、div2,它們都是左浮動,場景如下:
此時div1、div2都浮動,根據規則,div2會跟隨在div1後邊,但我們仍然希望div2能排列在div1下邊,就像div1沒有浮動,div2左浮動那樣。
這時候就要用到清除浮動(clear),如果單純根據官方定義,讀者可能會嘗試這樣寫:在div1的css樣式中新增clear:right;,理解為不允許div1的右邊有浮動元素,由於div2是浮動元素,因此會自動下移一行來滿足規則。
其實這種理解是不正確的,這樣做沒有任何效果。
對於css的清除浮動(clear),一定要牢記:這個規則只能影響使用清除的元素本身,不能影響其他元素。
怎麼理解呢?就拿上邊的例子來說,我們是想讓div2移動,但我們卻是在div1元素的css樣式中使用了清除浮動,試圖通過清除div1右邊的浮 動元素(clear:right;)來強迫div2下移,這是不可行的,因為這個清除浮動是在div1中呼叫的,它只能影響div1,不能影響div2。
要想讓div2下移,就必須在div2的css樣式中使用浮動。本例中div2的左邊有浮動元素div1,因此只要在div2的css樣式中使用clear:left;來指定div2元素左邊不允許出現浮動元素,這樣div2就被迫下移一行。
那麼假如頁面中只有兩個元素div1、div2,它們都是右浮動呢?讀者此時應該已經能自己推測場景,如下:
此時如果要讓div2下移到div1下邊,要如何做呢?
我們希望移動的是div2,就必須在div2的css樣式中呼叫浮動,因為浮動只能影響呼叫它的元素。可以看出div2的右邊有乙個浮動元素 div1,那麼我們可以在div2的css樣式中使用clear:right;來指定div2的右邊不允許出現浮動元素,這樣div2就被迫下移一行,排 到div1下邊。
CSS浮動詳解
關於浮動的基礎知識,這裡先引用w3school的一段介紹,在此基礎上我會新增一些註記和補充 浮動的框可以向左或向右移動,直到它的外邊緣碰到包含框或另乙個浮動框的邊框為止。由於浮動框不在文件的普通流中,所以文件的普通流中的塊框表現得就像浮動框不存在一樣。css 浮動 請看下圖,當把框 1 向右浮動時,...
CSS 清浮動詳解
使元素脫離文件流,按照指定方向發生移動,遇到父級邊界或者相鄰的元素停下來。脫離文件流 此時浮動元素在文件中不佔位置,飄了起來 1.塊元素在一行顯示 2.內聯元素支援寬高 3.預設內容撐開寬度 4.脫離文件流 5.提公升層級半層 只能夠放元素本身,這個元素裡的內容會被擠出來 6.父元素的高度無法被撐開...
css浮動布局詳解
浮動布局簡介 當元素浮動以後可以向左或向右移動,直到它的外邊緣碰到包含它的框或者另外乙個浮動元素的邊框為止。元素浮動以後會脫離正常的文件流,所以文件的普通流中的框就變現的好像浮動元素不存在一樣。類似於inline block 區別 第乙個 就是關於橫向排序的時候,float可以設定方向而inline...