浮動層自動適應高度的解決方法
發(fā)布時間:2010-07-23 18:36:21 作者:佚名
我要評論

在網頁制作中經常會用到浮動。用了浮動就會涉及到一個清除浮動的問題,因為包含浮動的元素是不會自動適應高度的,也就是不會被浮動元素撐開。
先看一個例子:
HTML:
<ul>
<li></li>
<li></li>
</ul>
CSS:
ul {
margin:0;
padding:10px;
list-style:none;
background-color:#006699;
}
ul li {
width:100px;
height:100px;
float:left;
margin-right:10px;
background-color:#99cc00;
}
在各個瀏覽器中的效果一致:

可以看到,外面 ul 即藍色的區(qū)域高度為0,如果沒有設置 padding,這個 ul 是看不到的。當然要讓它伸長也很簡單,只需要在最后一個 li 后面加一個標簽清楚下浮動就可以了。不過這樣的話就改變了HTML結構,不好?,F(xiàn)在這里要討論的就是如何在不改變結構的情況下讓 ul 自動伸長。
注意:自動伸長針對的是包含浮動元素的元素(這里是 ul)。而不是浮動元素自身(li)。
第一種方法:
IE 支持一個 CSS 屬性 zoom, 這個元素接受一個數(shù)字或一個百分數(shù),表示這個元素放大(縮小)的比例。例如:zoom:0.5或zoom:50% 表示縮小一半,而zoom:2或zoom:200%則表示放大一倍。
當定義了這個屬性之后在 IE 瀏覽器里面就會自動適應高度了。當應用了這個屬性之后,IE 就會自動伸長了。一般情況下我們不需要放大或縮小,所以定義 zoom:1 就行了?,F(xiàn)在的 CSS:
ul {
margin:0;
padding:10px;
list-style:none;
background-color:#006699;
zoom:1; /* IE */
}
而非 IE 瀏覽器不支持這個屬性。所以第一種方法需把瀏覽器分為兩個陣營:IE 和 非IE。
對于非 IE 瀏覽器需要用到一個偽類 :after (IE 瀏覽器不支持)。CSS 代碼如下:
ul:after {
content:".";
display:block;
clear:both;
height:0;
}
:after 偽類用于向元素后面插入一段內容,即 content 屬性。然后在這個插入的內容里清除浮動,我們可以想象成在最后一個 <li> 后面插入了一個 <span>.</span>里面的內容是一個”.”,然后設置display:block; clear:both; height:0; 等屬性 (這個比喻不一定準確)。
我們看下在 Firefox 下面的效果:

可以看到 ul 已經自動伸長了,但下面有個小小的黑點。相信你已經猜到了,這個黑點對應的就是 content:”.” 。
這個黑點肯定是要去掉的啦,我們可以用 font-size:0;line-height:0; 將其去掉。
好了,現(xiàn)在在兩個陣營的瀏覽器里都實現(xiàn)目標了。以下是 ul 所有的CSS代碼:
ul {
margin:0;
padding:10px;
list-style:none;
background-color:#006699;
zoom:1;/* IE */
}
ul:after {
content:".";
display:block;
clear:both;
height:0;
font-size:0;
line-height:0;
}
第二種方法
我剛說過不止一種方法可以解決,那現(xiàn)在就來說說第二種方法。第二種方法還要更簡單一些。同樣,需要將瀏覽器分成兩個陣營。不過和上一個有所不同,這一次 IE7 站到了另外一個陣營。即 IE7, Firefox, Opera, Safari 等(這里暫時稱為A瀏覽器)。對于這些瀏覽器,只要定義一個 overflow:auto; 即可,但是對于 IE6 和 IE5 (稱為B瀏覽器)卻不起作用。不過要 IE6,IE5 聽話也很簡單。只要定義一個高度即可,哪怕是 0 ,也會自動伸長。知道這些還沒用,我們還得區(qū)分這兩個陣營的瀏覽器才行。怎么區(qū)分呢?
A 瀏覽器支持屬性選擇符,而B瀏覽器不支持。
所以以下代碼只有A瀏覽器才會執(zhí)行。
[xmlns] ul { /* html[xmlns] ul 的簡寫 */
overflow:auto;
}
需要注意的是HTML 必須要有< !DOCTYPE >頭部以及<html>有xmlns屬性才會起作用。不過這個問題似乎不大,現(xiàn)在絕大部分網頁都有這兩個東東,包括 Dreamweaver 默認新建的網頁都會自動加上。
而對于B瀏覽器則可以通過以下方式:
* html ul {
height:1%;
}
其實 height 完全可以寫成 0,為什么要寫1%呢?告訴你其實我也不知道,大家都這么寫。
好了,第二種方法的 ul 全部樣式代碼如下:
ul {
margin:0;
padding:10px;
list-style:none;
background-color:#006699;
}
[xmlns] ul { /*html[xmlns] ul 的簡寫*/
overflow:auto;
}
* html ul {
height:1%;
}
現(xiàn)在既然有兩種方法,那么那一種更好呢?我個人比較喜歡第二種方法。原因很簡單,代碼更少,而且是符合標準的。只是在極少數(shù)情況下會出現(xiàn)滾動條,所以應該這兩種方法配合使用。
還有,這些代碼是可以通用的,可以提取為一個類比如 .clearfix 。這個任務就交給你自己完成吧。
HTML:
復制代碼
代碼如下:<ul>
<li></li>
<li></li>
</ul>
CSS:
復制代碼
代碼如下:ul {
margin:0;
padding:10px;
list-style:none;
background-color:#006699;
}
ul li {
width:100px;
height:100px;
float:left;
margin-right:10px;
background-color:#99cc00;
}
在各個瀏覽器中的效果一致:

可以看到,外面 ul 即藍色的區(qū)域高度為0,如果沒有設置 padding,這個 ul 是看不到的。當然要讓它伸長也很簡單,只需要在最后一個 li 后面加一個標簽清楚下浮動就可以了。不過這樣的話就改變了HTML結構,不好?,F(xiàn)在這里要討論的就是如何在不改變結構的情況下讓 ul 自動伸長。
注意:自動伸長針對的是包含浮動元素的元素(這里是 ul)。而不是浮動元素自身(li)。
第一種方法:
IE 支持一個 CSS 屬性 zoom, 這個元素接受一個數(shù)字或一個百分數(shù),表示這個元素放大(縮小)的比例。例如:zoom:0.5或zoom:50% 表示縮小一半,而zoom:2或zoom:200%則表示放大一倍。
當定義了這個屬性之后在 IE 瀏覽器里面就會自動適應高度了。當應用了這個屬性之后,IE 就會自動伸長了。一般情況下我們不需要放大或縮小,所以定義 zoom:1 就行了?,F(xiàn)在的 CSS:
復制代碼
代碼如下:ul {
margin:0;
padding:10px;
list-style:none;
background-color:#006699;
zoom:1; /* IE */
}
而非 IE 瀏覽器不支持這個屬性。所以第一種方法需把瀏覽器分為兩個陣營:IE 和 非IE。
對于非 IE 瀏覽器需要用到一個偽類 :after (IE 瀏覽器不支持)。CSS 代碼如下:
復制代碼
代碼如下:ul:after {
content:".";
display:block;
clear:both;
height:0;
}
:after 偽類用于向元素后面插入一段內容,即 content 屬性。然后在這個插入的內容里清除浮動,我們可以想象成在最后一個 <li> 后面插入了一個 <span>.</span>里面的內容是一個”.”,然后設置display:block; clear:both; height:0; 等屬性 (這個比喻不一定準確)。
我們看下在 Firefox 下面的效果:

可以看到 ul 已經自動伸長了,但下面有個小小的黑點。相信你已經猜到了,這個黑點對應的就是 content:”.” 。
這個黑點肯定是要去掉的啦,我們可以用 font-size:0;line-height:0; 將其去掉。
好了,現(xiàn)在在兩個陣營的瀏覽器里都實現(xiàn)目標了。以下是 ul 所有的CSS代碼:
復制代碼
代碼如下:ul {
margin:0;
padding:10px;
list-style:none;
background-color:#006699;
zoom:1;/* IE */
}
ul:after {
content:".";
display:block;
clear:both;
height:0;
font-size:0;
line-height:0;
}
第二種方法
我剛說過不止一種方法可以解決,那現(xiàn)在就來說說第二種方法。第二種方法還要更簡單一些。同樣,需要將瀏覽器分成兩個陣營。不過和上一個有所不同,這一次 IE7 站到了另外一個陣營。即 IE7, Firefox, Opera, Safari 等(這里暫時稱為A瀏覽器)。對于這些瀏覽器,只要定義一個 overflow:auto; 即可,但是對于 IE6 和 IE5 (稱為B瀏覽器)卻不起作用。不過要 IE6,IE5 聽話也很簡單。只要定義一個高度即可,哪怕是 0 ,也會自動伸長。知道這些還沒用,我們還得區(qū)分這兩個陣營的瀏覽器才行。怎么區(qū)分呢?
A 瀏覽器支持屬性選擇符,而B瀏覽器不支持。
所以以下代碼只有A瀏覽器才會執(zhí)行。
復制代碼
代碼如下:[xmlns] ul { /* html[xmlns] ul 的簡寫 */
overflow:auto;
}
需要注意的是HTML 必須要有< !DOCTYPE >頭部以及<html>有xmlns屬性才會起作用。不過這個問題似乎不大,現(xiàn)在絕大部分網頁都有這兩個東東,包括 Dreamweaver 默認新建的網頁都會自動加上。
而對于B瀏覽器則可以通過以下方式:
復制代碼
代碼如下:* html ul {
height:1%;
}
其實 height 完全可以寫成 0,為什么要寫1%呢?告訴你其實我也不知道,大家都這么寫。
好了,第二種方法的 ul 全部樣式代碼如下:
復制代碼
代碼如下:ul {
margin:0;
padding:10px;
list-style:none;
background-color:#006699;
}
[xmlns] ul { /*html[xmlns] ul 的簡寫*/
overflow:auto;
}
* html ul {
height:1%;
}
現(xiàn)在既然有兩種方法,那么那一種更好呢?我個人比較喜歡第二種方法。原因很簡單,代碼更少,而且是符合標準的。只是在極少數(shù)情況下會出現(xiàn)滾動條,所以應該這兩種方法配合使用。
還有,這些代碼是可以通用的,可以提取為一個類比如 .clearfix 。這個任務就交給你自己完成吧。
相關文章
- 當一個元素只包含浮動元素的時候,它會出現(xiàn)高度折疊,即元素的上下底邊重合,和高度為0效果一樣,針對這個問題與大家分享四種解決方法,感興趣的你可以參考下本文或許對你2013-03-04
- 剛入門網站設計布局的開發(fā)者肯定會碰到這樣的問題,那就是當子容器全部浮動的時候,父容器的高度不能自動撐開,今天偶也遇此問題,需要了解的朋友可以參考下2012-12-27
- 翻譯自Matthew James Taylor的Equal Height Columns with Cross-Browser CSS and No Hacks,有些部分根據我的理解改了,讓一些初心者更好理解。2009-11-12
- 由于浮動的元素脫離了文檔流,所以它們不會在網頁文檔中占據空間。如果一個DIV容器中想要包含這些浮動的元素的話,有兩種辦法。2011-08-02
CSS教程:div設置float后高度不自動增加-CSS教程-網頁制作-網頁教學網
相關文章:http://www.webjx.com/css/divcss-4952.html http://www.webjx.com/css/divcss-5991.html 本來想把這個題目修改為“閉合浮動元素”或&l2008-10-17- 在進行浮動布局時,大多數(shù)人都深知,在必要的地方進行浮動清理:。2009-09-03
- 在ie8、chrome瀏覽器中,包裹浮動的li元素的外層ul高度為0,ie7瀏覽器和ie8兼容模式顯示正常,下面與大家分享下多種解決方法大家可以根據情況自由選擇,希望對大家有所幫助2013-07-31