偽元素清除浮動(重要)


利用偽元素:after清除浮動

 

讓頁面呈現多列布局時經常會使用  float:left/right ,可是浮動布局會導致父元素的高度為0(未設置高度的情況下),不會根據子元素的高度而變化,另外,后面不需要浮動想在下一行顯示的標簽出現在浮動元素的后面。

#content{background:#000;}
.left{width:100px;height:100px;background:#eee;margin:0 10px;float:left;}

所以我們在使用浮動進行布局的時候會需要一個塊級元素(行內元素無效)來設置 clear 屬性,如果浮動元素下方本來就有元素,那我們可以直接對該元素設置 clear:both ,若沒有其他元素需要展示,我們往往會寫一個空白標簽來清除浮動

<div style="clear:both"></div>

但是這樣無疑會增加瀏覽器的渲染負擔,所以考慮使用偽元素 :after 來代替這個空白標簽,因為清除浮動需要在浮動元素后面,所以不可以使用 :before ,對 :after 設置 content:"" ,並使其 display:block 成為塊級元素后 clear:both 來清除浮動:

#content:after{content:"";display:block;clear:both;}

該方法在 ie6、7 中無效,需要對 #content 設置 zoom:1。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM