CSS浮動
首先div是塊級元素,在頁面中獨占一行,自? 上而下排列宗雇。
????????? 以上可以看出,即使div1de寬度很小莹规,頁面中一行可以容下div1 和div2赔蒲, div2頁不會排在div1后邊,因為div1元素是獨占一行的良漱。
?? 注意舞虱,以上這些理論,是指標準中的div母市。無論多么復雜的布局矾兜,其基本出發(fā)的均是:“如何在一行顯示多個div元素”。
顯然標準div流已經(jīng)無法滿足需求患久,這就要用到浮動了椅寺,浮動可以理解為讓莫個div元素脫離標準流浑槽,漂浮在標準流之上,和標準流不是一個層次返帕。
列如:
假設上圖中的div2浮動桐玻,那么它將脫離標準流,但div1,div2,div3,仍然在標準當中荆萤,所以div3會自動向上移動镊靴,占據(jù)div2de位置,重新組成一個流链韭。
從圖中可以看出偏竟,由于對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之后蛾方,不知道讀者有沒有發(fā)現(xiàn),一直到現(xiàn)在上陕,div2在每個例子中都是浮動的桩砰,但并沒有跟隨到div1之后。因此释簿,我們可以得出一個重要結論:
假如某個div元素A是浮動的亚隅,如果A元素上一個元素也是浮動的,那么A元素會跟隨在上一個元素的后邊(如果一行放不下這兩個元素庶溶,那么A元素會被擠到下一行)煮纵;如果A元素上一個元素是標準流中的元素,那么A的相對垂直位置不會改變偏螺,也就是說A的頂部總是和上一個元素的底部對齊行疏。
為了幫助讀者理解,再舉幾個例子套像。
假如我們把div2酿联、div3、div4都設置成左浮動夺巩,效果如下:
根據(jù)上邊的結論:先從div4開始分析贞让,它發(fā)現(xiàn)上邊的元素div3是浮動的,所以div4會跟隨在div3之后柳譬;div3發(fā)現(xiàn)上邊的元素div2也是浮動的喳张,所以div3會跟隨在div2之后;而div2發(fā)現(xiàn)上邊的元素div1是標準流中的元素征绎,因此div2的相對垂直位置不變蹲姐,頂部仍然和div1元素的底部對齊。由于是左浮動人柿,左邊靠近頁面邊緣柴墩,所以左邊是前,因此div2在最左邊凫岖。
假如把div2江咳、div3、div4都設置成右浮動哥放,效果如下:
假如我們只把div2挟阻、div4左浮動琼娘,效果圖如下:
依然是根據(jù)結論,div2附鸽、div4浮動脱拼,脫離了標準流,因此div3將會自動上移坷备,與div1組成標準流熄浓。div2發(fā)現(xiàn)上一個元素div1是標準流中的元素,因此div2相對垂直位置不變省撑,與div1底部對齊赌蔑。div4發(fā)現(xiàn)上一個元素div3是標準流中的元素,因此div4的頂部和div3的底部對齊丁侄,并且總是成立的惯雳,因為從圖中可以看出,div3上移后鸿摇,div4也跟著上移石景,div4總是保證自己的頂部和上一個元素div3(標準流中的元素)的底部對齊。
至此拙吉,恭喜讀者已經(jīng)掌握了添加浮動潮孽,但還有清除浮動,有上邊的基礎清除浮動非常容易理解筷黔。
經(jīng)過上邊的學習往史,可以看出:元素浮動之前,也就是在標準流中佛舱,是豎向排列的椎例,而浮動之后可以理解為橫向排列。
清除浮動可以理解為打破橫向排列请祖。
清除浮動的關鍵字是clear订歪,官方定義如下:
這時候就要用到清除浮動(clear),如果單純根據(jù)官方定義肆捕,讀者可能會嘗試這樣寫:在div1的CSS樣式中添加clear:right;刷晋,理解為不允許div1的右邊有浮動元素,由于div2是浮動元素,因此會自動下移一行來滿足規(guī)則眼虱。
其實這種理解是不正確的喻奥,這樣做沒有任何效果。
對于CSS的清除浮動(clear)捏悬,一定要牢記:這個規(guī)則只能影響使用清除的元素本身撞蚕,不能影響其他元素。
怎么理解呢邮破?就拿上邊的例子來說诈豌,我們是想讓div2移動,但我們卻是在div1元素的CSS樣式中使用了清除浮動抒和,試圖通過清除div1右邊的浮動元素(clear:right;)來強迫div2下移,這是不可行的彤蔽,因為這個清除浮動是在div1中調(diào)用的摧莽,它只能影響div1,不能影響div2顿痪。
要想讓div2下移镊辕,就必須在div2的CSS樣式中使用浮動。本例中div2的左邊有浮動元素div1蚁袭,因此只要在div2的CSS樣式中使用clear:left;來指定div2元素左邊不允許出現(xiàn)浮動元素征懈,這樣div2就被迫下移一行。
那么假如頁面中只有兩個元素div1揩悄、div2卖哎,它們都是右浮動呢?讀者此時應該已經(jīng)能自己推測場景删性,如下: