CSS教程:弄懂閉合浮動(dòng)元素
按照CSS規范,浮動(dòng)元素(floats)會(huì )被移出文檔流,不會(huì )影響到塊狀盒子的布局而只會(huì )影響內聯(lián)盒子(通常是文本)的排列。因此當其高度超出包含容器時(shí),一般父容器不會(huì )自動(dòng)伸長(cháng)以閉合浮動(dòng)元素。但是有時(shí)我們卻需要這種自動(dòng)閉合行為,具體如何處理呢?
有一種做法就是在父容器內再插入一個(gè)額外的標簽,并令其清除浮動(dòng)(clear)以撐大父容器。這種方法瀏覽器兼容性好,沒(méi)有什么問(wèn)題,缺點(diǎn)就是需要額外的(而且通常是無(wú)語(yǔ)義的)標簽,所以我個(gè)人不大喜歡。
后來(lái)又有了一種新的方式,使用:after偽類(lèi)動(dòng)態(tài)的嵌入一個(gè)用于清除浮動(dòng)的元素,這種方法和上一種原理一樣,不同的只是把這個(gè)額外的內容用CSS生成,但考慮到IE不支持:after不得不做了不少的hack。這種方法兼容性一般,但經(jīng)過(guò)各種hack也可以應付不同瀏覽器了,同時(shí)又可以保證html比較干凈,所以用得還是比較多的。
再后來(lái)又有人發(fā)現將父容器的overflow設為除visible之外的值就可以在標準兼容瀏覽器中閉合浮動(dòng)元素,IE自然又是不支持的,所以這種方法和上一種方法一樣都對IE做了不同處理(具體就是觸發(fā)layout),不同的就是overflow沒(méi)有:after偽類(lèi)那么麻煩了,缺點(diǎn)也有,overflow可能會(huì )產(chǎn)生一些小沖突。
在使用overflow之前還有過(guò)一種使用float的方法,就是讓父容器也浮動(dòng),這利用到了浮動(dòng)元素的一個(gè)特性——浮動(dòng)元素會(huì )閉合浮動(dòng)元素。這種方式在IE/Win和標準兼容瀏覽器中都有較好的效果,但缺點(diǎn)也很明顯——父容器未必想浮動(dòng)就浮動(dòng)的了,畢竟浮動(dòng)是一種比較特殊的行為,有時(shí)布局不允許其浮動(dòng)也很正常。使用float雖然在IE和標準兼容瀏覽器中都能閉合浮動(dòng)元素,但原理卻是不同的,IE/Win中 float觸發(fā)了layout因而閉合了浮動(dòng),而在標準兼容瀏覽器中,float其實(shí)和上一種方法中的overflow原理一樣,產(chǎn)生了一個(gè)“塊級格式化范圍”——這是CSS規范中提到的一種現象,它往往具有某種獨立性,特性之一就是會(huì )自動(dòng)閉合內部的浮動(dòng)元素。
按照規范,以下類(lèi)型的元素會(huì )產(chǎn)生一個(gè)塊級格式化范圍:
●浮動(dòng)元素,left或者right皆可。
●絕對定位的元素。
● inline-block元素,不過(guò)這個(gè)gecko目前不支持。
● table-cell類(lèi)型元素,其實(shí)table, table-head-group, table-row什么的也都可以,還有inline-table(gecko不支持)也同樣,因為他們都會(huì )間接產(chǎn)生一個(gè)匿名的table-cell。
● overflow取值非visible的元素。
所以,原來(lái)在標準兼容瀏覽器中我們也可以有這么多的方法閉合一個(gè)浮動(dòng)元素,而且只需要CSS,無(wú)需其他。順帶說(shuō)一下以上除了overflow,其余都有一個(gè)附加效果就是自動(dòng)收縮父容器寬度。
而對于IE/Win,它有一套自己的體系,就是layout,具有layout的元素會(huì )自動(dòng)閉合浮動(dòng)元素,再來(lái)看看觸發(fā)layout的 CSS屬性,會(huì )發(fā)現和上面的塊級格式化范圍有很多類(lèi)似之處:
●浮動(dòng)元素
●絕對定位元素
● display:inline-block
● zoom
● width/height
● overflow/overflow-x/overflow-y [IE7新增]
● max/min-width/height [IE7新增]
以上來(lái)看IE中閉合浮動(dòng)元素的方法也不少,自然也都有其局限性,要么有附帶效果,要么使用的是非標準屬性(無(wú)法通過(guò)驗證)。
還要提一點(diǎn)的是display:inline-block,這個(gè)屬性對IE而言本身沒(méi)什么用,實(shí)際效果只是給一個(gè)元素暗地添加了layout,但是標準兼容瀏覽器是認得這個(gè)屬性的,所以要不影響這些瀏覽器,需要將display設回默認。這里IE有一個(gè)bug,如果先定義了display:inline-block,然后再將display設回block(這兩個(gè)display要先后放在兩個(gè)CSS聲明中才有效果),那么layout不會(huì )消失,同時(shí)也不會(huì )影響其他瀏覽器,所以目前來(lái)說(shuō),這也算一個(gè)不錯的觸發(fā)layout的方法:
.gainlayout{display:inline-block;}
.gainlayout{display:block;}
所以要跨瀏覽器閉合浮動(dòng)元素,可以選擇的方式還是很多的,如何搭配使用這些CSS屬性就要具體情況具體分析了,靈活應用條件注釋也很有必要,要是實(shí)在不行我們回過(guò)頭來(lái)還有clear可以用嘛。
- 相關(guān)閱讀
- 長(cháng)春海外旅游有限責任責任公司
- 金岸國際旅行社
- 一個(gè)簡(jiǎn)單的用java寫(xiě)的非常不錯的貪食蛇游戲
- 了解html基礎知識之html標簽集合
- 利用java使圖片左右上下循環(huán)連續滾動(dòng)不出現空白
- windows xp設置IIS。
- 深山留言板系統V3.6(游戲之穿越火線(xiàn)幽靈歸來(lái))
- 深山旅行社網(wǎng)站管理系統 v1.5
- 共有0條關(guān)于《CSS教程:弄懂閉合浮動(dòng)元素》的評論
- 發(fā)表評論
呢 稱(chēng): | |
表 情: | |
內 容: |
評論內容:不能超過(guò) 1000 字,需審核,請自覺(jué)遵守互聯(lián)網(wǎng)相關(guān)政策法規。 |
驗證碼: | |
您發(fā)布的評論即表示同意遵守以下條款:
一、不得利用本站危害國家安全、泄露國家秘密,不得侵犯國家、社會(huì )、集體和公民的合法權益;
二、不得發(fā)布國家法律、法規明令禁止的內容;互相尊重,對自己在本站的言論和行為負責;
三、本站對您所發(fā)布內容擁有處置權。
- 更多信息>>欄目類(lèi)別選擇
- 百度小程序開(kāi)發(fā)
- 微信小程序開(kāi)發(fā)
- 微信公眾號開(kāi)發(fā)
- uni-app
- asp函數庫
- ASP
- DIV+CSS
- HTML
- python
- 更多>>同類(lèi)信息
- jquery設置或獲取修改classname
- 利用css3.0寫(xiě)出一個(gè)音樂(lè )播放的唱片碟盤(pán)的效果
- 利用css中的scale()實(shí)現放大縮小效果
- 利用background-color:#000000a8在背景顏色16進(jìn)制代碼之后加字母加上數字讓背景色透明
- css背景使用base64編碼或者將base64編碼放在img圖片標簽中
- 利用css3中的-webkit-font-smoothing把網(wǎng)頁(yè)文字的毛邊去掉
- 更多>>最新添加文章
- 抖音直播音掛載小雪花 懂車(chē)帝小程序
- javascript獲取瀏覽器指紋可以用來(lái)做投票
- 火狐Mozilla Firefox出現:無(wú)法載入您的Firefox配置文件 它可能已經(jīng)丟失 或是無(wú)法訪(fǎng)問(wèn) 問(wèn)題解決集合處理辦法
- 在A(yíng)ndroid、iOS、Windows、MacOS中微信小程序的文件存放路徑
- python通過(guò)代碼修改pip下載源讓下載庫飛起
- python里面requests.post返回的res.text還有其它的嗎
- aliyun阿里云續費域名優(yōu)惠口令(注冊、續費都可以使用)
- windows7環(huán)境下安裝配置jdk