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

       經過上邊的學習,可以看出:元素浮動之前,也就是在標準流中,是豎向排列的,而浮動之後可以理解爲橫向排列。

       清除浮動可以理解爲打破橫向排列。

       清除浮動的關鍵字是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+DIV浮動定位基本原理,足以應付常見的佈局。

         其實,萬變不離其宗,只要讀者用心體會,再複雜的佈局都可以通過小編總結的規律搞定。

      寫在後面的話: 

         必須嚴正聲明,CSS這塊極其混亂,尤其是瀏覽器的兼容性問題。

         其實真不想寫這麼長的文章,可爲了讀者能夠理解,總是不由自主的想多舉些例子。

         爲了減輕讀者心理壓力,本文沒有任何CSS、HTML代碼,因爲現在很多教程上來就是一大堆CSS代碼,看到就煩,別說細讀了。

         最後預祝讀者閱讀愉快,開心掌握知識。

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


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