CSS浮動(float,clear)通俗講解(一)

寫在前面的話:

   由於CSS內容比較多,小編沒有精力從頭到尾講一遍,只能有針對性的講解。

   如果讀者理解CSS盒子模型,但對於浮動不理解,那麼這篇文章可以幫助你。

   本文以div元素佈局爲例。

教程開始:

   首先要知道,div是塊級元素,在頁面中獨佔一行,自上而下排列,也就是傳說中的流。如下圖:

CSS浮動(float,clear)通俗講解(一)

   可以看出,即使div1的寬度很小,頁面中一行可以容下div1和div2,div2也不會排在div1後邊,因爲div元素是獨佔一行的。

   注意,以上這些理論,是指標準流中的div。

   小編認爲,無論多麼複雜的佈局,其基本出發點均是:“如何在一行顯示多個div元素”。

   顯然標準流已經無法滿足需求,這就要用到浮動。      

   浮動可以理解爲讓某個div元素脫離標準流,漂浮在標準流之上,和標準流不是一個層次。

   例如,假設上圖中的div2浮動,那麼它將脫離標準流,但div1、div3、div4仍然在標準流當中,所以div3會自動向上移動,佔據div2的位置,重新組成一個流。如圖:

CSS浮動(float,clear)通俗講解(一)

   從圖中可以看出,由於對div2設置浮動,因此它不再屬於標準流,div3自動上移頂替div2的位置,div1、div3、div4依次排列,成爲一個新的流。又因爲浮動是漂浮在標準流之上的,因此div2擋住了一部分div3,div3看起來變“矮”了。

   這裏div2用的是左浮動(float:left;),可以理解爲漂浮起來後靠左排列,右浮動(float:right;)當然就是靠右排列。這裏的靠左、靠右是說頁面的左、右邊緣。

   如果我們把div2採用右浮動,會是如下效果:

CSS浮動(float,clear)通俗講解(一)

   此時div2靠頁面右邊緣排列,不再遮擋div3,讀者可以清晰的看到上面所講的div1、div3、div4組成的流。

   目前爲止我們只浮動了一個div元素,多個呢?

   下面我們把div2和div3都加上左浮動,效果如圖:

CSS浮動(float,clear)通俗講解(一)

   同理,由於div2、div3浮動,它們不再屬於標準流,因此div4會自動上移,與div1組成一個“新”標準流,而浮動是漂浮在標準流之上,因此div2又擋住了div4。

   咳咳,到重點了,當同時對div2、div3設置浮動之後,div3會跟隨在div2之後,不知道讀者有沒有發現,一直到現在,div2在每個例子中都是浮動的,但並沒有跟隨到div1之後。因此,我們可以得出一個重要結論:

   假如某個div元素A是浮動的,如果A元素上一個元素也是浮動的,那麼A元素會跟隨在上一個元素的後邊(如果一行放不下這兩個元素,那麼A元素會被擠到下一行);如果A元素上一個元素是標準流中的元素,那麼A的相對垂直位置不會改變,也就是說A的頂部總是和上一個元素的底部對齊。

   div的順序是HTML代碼中div的順序決定的。

   靠近頁面邊緣的一端是前,遠離頁面邊緣的一端是後。

CSS浮動(float,clear)通俗講解(一)

   爲了幫助讀者理解,再舉幾個例子。

   假如我們把div2、div3、div4都設置成左浮動,效果如下:

CSS浮動(float,clear)通俗講解(一)

   根據上邊的結論,跟着小編理解一遍:先從div4開始分析,它發現上邊的元素div3是浮動的,所以div4會跟隨在div3之後;div3發現上邊的元素div2也是浮動的,所以div3會跟隨在div2之後;而div2發現上邊的元素div1是標準流中的元素,因此div2的相對垂直位置不變,頂部仍然和div1元素的底部對齊。由於是左浮動,左邊靠近頁面邊緣,所以左邊是前,因此div2在最左邊。

   假如把div2、div3、div4都設置成右浮動,效果如下:

CSS浮動(float,clear)通俗講解(一)

   道理和左浮動基本一樣,只不過需要注意一下前後對應關係。由於是右浮動,因此右邊靠近頁面邊緣,所以右邊是前,因此div2在最右邊。

   假如我們把div2、div4左浮動,效果圖如下:

CSS浮動(float,clear)通俗講解(一)

   依然是根據結論,div2、div4浮動,脫離了標準流,因此div3將會自動上移,與div1組成標準流。div2發現上一個元素div1是標準流中的元素,因此div2相對垂直位置不變,與div1底部對齊。div4發現上一個元素div3是標準流中的元素,因此div4的頂部和div3的底部對齊,並且總是成立的,因爲從圖中可以看出,div3上移後,div4也跟着上移,div4總是保證自己的頂部和上一個元素div3(標準流中的元素)的底部對齊。

   至此,恭喜讀者已經掌握了添加浮動,但還有清除浮動,有上邊的基礎清除浮動非常容易理解。

想要學習更多WEB前端開發知識,歡迎加入WEB開發交流羣-8(羣號:143046757)獲取更多資料~

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章