閉合浮動(dòng)元素讓CSS代碼更規(guī)范
互聯(lián)網(wǎng) 發(fā)布時(shí)間:2008-10-17 19:28:36 作者:佚名
我要評(píng)論

按照CSS規(guī)范,浮動(dòng)元素(floats)會(huì)被移出文檔流,不會(huì)影響到塊狀盒子的布局而只會(huì)影響內(nèi)聯(lián)盒子(通常是文本)的排列。因此當(dāng)其高度超出包含容器時(shí),一般父容器不會(huì)自動(dòng)伸長(zhǎng)以閉合浮動(dòng)元素。但是有時(shí)我們卻需要這種自動(dòng)閉合行為,具體如何處理呢?
有一種做法就是在父容
按照CSS規(guī)范,浮動(dòng)元素(floats)會(huì)被移出文檔流,不會(huì)影響到塊狀盒子的布局而只會(huì)影響內(nèi)聯(lián)盒子(通常是文本)的排列。因此當(dāng)其高度超出包含容器時(shí),一般父容器不會(huì)自動(dòng)伸長(zhǎng)以閉合浮動(dòng)元素。但是有時(shí)我們卻需要這種自動(dòng)閉合行為,具體如何處理呢?
有一種做法就是在父容器內(nèi)再插入一個(gè)額外的標(biāo)簽,并令其清除浮動(dòng)(clear)以撐大父容器。這種方法瀏覽器兼容性好,沒有什么問題,缺點(diǎn)就是需要額外的(而且通常是無語義的)標(biāo)簽,所以我個(gè)人不大喜歡。后來又有了一種新的方式,使用:after偽類動(dòng)態(tài)的嵌入一個(gè)用于清除浮動(dòng)的元素,這種方法和上一種原理一樣,不同的只是把這個(gè)額外的內(nèi)容用CSS生成,但考慮到IE不支持:after不得不做了不少的hack。這種方法兼容性一般,但經(jīng)過各種hack也可以應(yīng)付不同瀏覽器了,同時(shí)又可以保證html比較干凈,所以用得還是比較多的。再后來又有人發(fā)現(xiàn)將父容器的overflow設(shè)為除visible之外的值就可以在標(biāo)準(zhǔn)兼容瀏覽器中閉合浮動(dòng)元素,IE自然又是不支持的,所以這種方法和上一種方法一樣都對(duì)IE做了不同處理(具體就是觸發(fā)layout),不同的就是overflow沒有:after偽類那么麻煩了,缺點(diǎn)也有,overflow可能會(huì)產(chǎn)生一些小沖突。在使用overflow之前還有過一種使用float的方法,就是讓父容器也浮動(dòng),這利用到了浮動(dòng)元素的一個(gè)特性——浮動(dòng)元素會(huì)閉合浮動(dòng)元素。這種方式在IE/Win和標(biāo)準(zhǔn)兼容瀏覽器中都有較好的效果,但缺點(diǎn)也很明顯——父容器未必想浮動(dòng)就浮動(dòng)的了,畢竟浮動(dòng)是一種比較特殊的行為,有時(shí)布局不允許其浮動(dòng)也很正常。使用float雖然在IE和標(biāo)準(zhǔn)兼容瀏覽器中都能閉合浮動(dòng)元素,但原理卻是不同的,IE/Win中float觸發(fā)了layout因而閉合了浮動(dòng),而在標(biāo)準(zhǔn)兼容瀏覽器中,float其實(shí)和上一種方法中的overflow原理一樣,產(chǎn)生了一個(gè)“塊級(jí)格式化范圍”——這是CSS規(guī)范中提到的一種現(xiàn)象,它往往具有某種獨(dú)立性,特性之一就是會(huì)自動(dòng)閉合內(nèi)部的浮動(dòng)元素。
按照規(guī)范,以下類型的元素會(huì)產(chǎn)生一個(gè)塊級(jí)格式化范圍:
浮動(dòng)元素,left或者right皆可。
絕對(duì)定位的元素。
inline-block元素,不過這個(gè)gecko目前不支持。
table-cell類型元素,其實(shí)table,table-head-group,table-row什么的也都可以,還有inline-table(gecko不支持)也同樣,因?yàn)樗麄兌紩?huì)間接產(chǎn)生一個(gè)匿名的table-cell。
overflow取值非visible的元素。
所以,原來在標(biāo)準(zhǔn)兼容瀏覽器中我們也可以有這么多的方法閉合一個(gè)浮動(dòng)元素,而且只需要CSS,無需其他。順帶說一下以上除了overflow,其余都有一個(gè)附加效果就是自動(dòng)收縮父容器寬度。
而對(duì)于IE/Win,它有一套自己的體系,就是layout,具有l(wèi)ayout的元素會(huì)自動(dòng)閉合浮動(dòng)元素,再來看看觸發(fā)layout的CSS屬性,會(huì)發(fā)現(xiàn)和上面的塊級(jí)格式化范圍有很多類似之處: 浮動(dòng)元素
絕對(duì)定位元素
display:inline-block
zoom
width/height
overflow/overflow-x/overflow-y[IE7新增]
max/min-width/height[IE7新增]
以上來看IE中閉合浮動(dòng)元素的方法也不少,自然也都有其局限性,要么有附帶效果,要么使用的是非標(biāo)準(zhǔn)屬性(無法通過驗(yàn)證)。
還要提一點(diǎn)的是display:inline-block,這個(gè)屬性對(duì)IE而言本身沒什么用,實(shí)際效果只是給一個(gè)元素暗地添加了layout,但是標(biāo)準(zhǔn)兼容瀏覽器是認(rèn)得這個(gè)屬性的,所以要不影響這些瀏覽器,需要將display設(shè)回默認(rèn)。這里IE有一個(gè)bug,如果先定義了display:inline-block,然后再將display設(shè)回block(這兩個(gè)display要先后放在兩個(gè)CSS聲明中才有效果),那么layout不會(huì)消失,同時(shí)也不會(huì)影響其他瀏覽器,所以目前來說,這也算一個(gè)不錯(cuò)的觸發(fā)layout的方法:
Example Source Code
.gainlayout{display:inline-block;}
.gainlayout{display:block;}
所以要跨瀏覽器閉合浮動(dòng)元素,可以選擇的方式還是很多的,如何搭配使用這些CSS屬性就要具體情況具體分析了,靈活應(yīng)用條件注釋也很有必要,要是實(shí)在不行我們回過頭來還有clear可以用嘛。
相關(guān)文章
- 這里為大家送上一份CSS代碼書寫規(guī)范究極指南,包括代碼注釋和命名規(guī)范以及空格縮進(jìn)等一應(yīng)俱全,都來自大家平時(shí)的約定俗成,絕對(duì)值得學(xué)習(xí)借鑒,需要的朋友可以參考下2016-05-27
編寫靈活、穩(wěn)定、高質(zhì)量的HTML和css代碼規(guī)范指南
這篇文章主要介紹了編寫靈活、穩(wěn)定、高質(zhì)量的HTML和css代碼規(guī)范指南,如何書寫規(guī)范的html以及css代碼,大家可以參考下文進(jìn)行學(xué)習(xí)2016-03-10全面總結(jié)CSS代碼的編寫規(guī)范及優(yōu)化建議
這篇文章主要介紹了全面總結(jié)CSS代碼的編寫規(guī)范及優(yōu)化建議,從最基本的代碼塊格式到模塊化再到性能優(yōu)化,整理得相當(dāng)詳細(xì),十分推薦!需要的朋友可以參考下2016-02-23css代碼縮寫 div+css布局代碼簡(jiǎn)寫規(guī)范
采用css縮寫div+css布局代碼,你會(huì)發(fā)現(xiàn)很簡(jiǎn)潔很好看也是對(duì)網(wǎng)頁布局者的一個(gè)比較高的要求吧,接下來為網(wǎng)頁愛好者詳細(xì)介紹下,css樣式中常用的縮寫語法,感性的朋有可以參考2013-03-22- 19UED前端CSS代碼規(guī)范 V1.0.2012-06-13
- 網(wǎng)頁制作Webjx文章簡(jiǎn)介:Eric Meyer Reset和YUI Reset都是非常強(qiáng)大的,但是對(duì)于我而言,它們走的太遠(yuǎn)了。我覺得你最終需要重置一切,然后重新定義所有元素的屬性。這就是為2009-04-02
- 本文是腳本之家小編給大家分享的20條書寫CSS代碼的建議,感興趣的朋友一起看看吧2018-06-08