DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> CSS入門知識 >> CSS詳解 >> 更簡潔CSS清理浮動方式:clearfix
更簡潔CSS清理浮動方式:clearfix
編輯:CSS詳解     

清理浮動有很多種方式,像使用 br 標簽自帶的 clear 屬,使用元素的 overflow,使用空標簽來設置 clear:both 等等。但考慮到兼容問題和語義化的問題,一般我們都會使用如下代碼來清理浮動。

 


  1. /* 清理浮動 */  
  2. .clearfix:after {  
  3.     visibility:hidden;  
  4.     display:block;  
  5.     font-size:0;  
  6.     content:" ";  
  7.     clear:both;  
  8.     height:0;  
  9. }  
  10. .clearfix {  
  11.     zoom:1;  

 

其原理是,在「高級」浏覽器中使用 :after 偽類在浮動塊後面加上一個非 display:none 的不可見塊狀內容來,並給它設置 clear:both 來清理浮動。在 ie6 和 7 中給浮動塊添加 haslayout 來讓浮動塊撐高並正常影響文檔流。

上面的代碼應該是現在主流的清理浮動方式。現在支付寶就使用這樣的方式。

而現在,Nicolas Gallagher 給出了一個更簡潔的方案:

 


  1. .cf:before, .cf:after {  
  2.     content:"";  
  3.     display:table;  
  4. }  
  5. .cf:after {  
  6.     clear:both;  
  7. }  
  8. .cf {  
  9.     zoom:1;  
  10. }  

 

原理還是一樣的。使用 :after 偽類來提供浮動塊後的 clear:both。不同的是,隱藏這個空白使用的是 display: table。而不是設置 visibility:hidden;height:0;font-size:0; 這樣的 hack。

值得注意的是這裡中的 :before 偽類。其實他是來用處理 top-margin 邊折疊的,跟清理浮動沒有多大的關系。但因為浮動會創建 block formatting context,這樣浮動元素上的另而一元素上如果剛好有 margin-bottom 而這個浮動元素剛好有margin-top 的話,應該讓他們不折疊(雖然這種情況並不常見)。

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved