1. 程式人生 > >css清除浮動clearfix:after的用法詳解(轉)

css清除浮動clearfix:after的用法詳解(轉)

三種方式 用法 html 解決 解決方法 閱讀 inline 轉移 entry

css清除浮動clearfix:after的用法詳解

2015-12-10 23:11 by 流浪的詩人, 8099 閱讀, 0 評論, 收藏, 編輯

如果外部有一個div容器,其內部div容器設置了float樣式,則外部的容器div因為內部沒有clear,導致不能撐開。
解決方法:

CSS代碼:

復制代碼 代碼如下:

.clearfix:after {
content: "." ;
display: block ;
height: 0 ;
clear: both ;
visibility: hidden ;
}
.clearfix{ display: inline-block; }
/* Hides from IE-mac */
*html .clearfix{ height:1%; }
.clearfix{ display:block; }
/* End hide from IE-mac */

//clearfix的CSS使用了after這個偽對象
//應用clearfix的元素的結尾添加content中的內容
//轉移字符“ ”,Mac IE瀏覽器會忽略掉這段Hack,但是Windows IE不會
以下是詳細解釋:
首先 清除浮動的原理 ,其實 是元素留出足夠多的 垂直外邊距 給浮動的元素。

復制代碼 代碼如下:

<div >
<div style="float:left"></div>
</div>
這個效果 是 外層div不會包含內層div。因為浮動的元素 脫離了原始文檔流。
以上面這個為例:一般而言 ,有三種方式清除浮動
。第一:讓外層元素也浮動,例如:

復制代碼 代碼如下:

<div style="float:left" >
<div style="float:left"></div>
</div>
然後 再此元素之外 的元素上添加clear:both效果。
第二:給外層div的末尾添加一個元素,並利用此元素清楚浮動。
具體用法:

復制代碼 代碼如下:

<div style="clearfix" >
<div style="float:left"></div>
</div>
.clearfix:atfer{
content:".";
display:block;
visibility:hidden;
height:0;
clear:both;
}

.clearfix{display:inline-block}
.clearfix{display:block}
其中後面的兩個 是為了兼容其他瀏覽器設置的。因為:after不是所有瀏覽器都支持的。
第三:利用 overflow屬性

復制代碼 代碼如下:

<div style="overflow:hidden" >
<div style="float:left"></div>
</div>

css清除浮動clearfix:after的用法詳解(轉)