<button id="nc8ni"><xmp id="nc8ni"><button id="nc8ni"></button><ins id="nc8ni"><button id="nc8ni"><form id="nc8ni"></form></button></ins>
<button id="nc8ni"><form id="nc8ni"></form></button>
<form id="nc8ni"><xmp id="nc8ni">
<ins id="nc8ni"><button id="nc8ni"></button></ins>
<button id="nc8ni"><xmp id="nc8ni">
<ins id="nc8ni"><form id="nc8ni"><ins id="nc8ni"></ins></form></ins>
<button id="nc8ni"><xmp id="nc8ni">
<button id="nc8ni"><xmp id="nc8ni">
<button id="nc8ni"><form id="nc8ni"><ins id="nc8ni"></ins></form></button><button id="nc8ni"><form id="nc8ni"></form></button>
<button id="nc8ni"><form id="nc8ni"><ins id="nc8ni"></ins></form></button><button id="nc8ni"><xmp id="nc8ni"><button id="nc8ni"></button><form id="nc8ni"><ins id="nc8ni"><form id="nc8ni"></form></ins></form><button id="nc8ni"><xmp id="nc8ni"><ins id="nc8ni"></ins>
<button id="nc8ni"><xmp id="nc8ni"><ins id="nc8ni"></ins><form id="nc8ni"><ins id="nc8ni"><form id="nc8ni"></form></ins></form>
<ins id="nc8ni"><form id="nc8ni"></form></ins>
<button id="nc8ni"><form id="nc8ni"><ins id="nc8ni"></ins></form></button>
<button id="nc8ni"></button>
<button id="nc8ni"></button>
訂閱本欄目 RSS您所在的位置: 深山工作室 > DIV+CSS > 正文

CSS教程:弄懂閉合浮動(dòng)元素

網(wǎng)絡(luò ) 2008/6/29 20:45:46 深山行者 字體: 瀏覽 6374

按照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ā)表評論
正在加載評論......
返回頂部發(fā)表評論
呢 稱(chēng):
表 情:
內 容:
評論內容:不能超過(guò) 1000 字,需審核,請自覺(jué)遵守互聯(lián)網(wǎng)相關(guān)政策法規。
驗證碼: 驗證碼 
網(wǎng)友評論聲明,請自覺(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
更多>>隨機抽取信息
網(wǎng)站SEO優(yōu)化應該注意的14點(diǎn)重要事項
深山旅游網(wǎng)站管理系統V1.0
asp利用函數生成指定位數的隨機數字符串
判斷輸入字符串中是否含有危險字符
各個(gè)蘋(píng)果手表型號版本對比以及查看蘋(píng)果手機Apple Watch型號
uni-app基礎知識事件綁定@click與@tap點(diǎn)擊事件區別
亚洲精品456在线|S级爆乳玩具酱国产VIP皮裤|欧美成人精品第一区二区三区|久久永久免费人妻精品我不卡|亚洲欧洲日产无码
<button id="nc8ni"><xmp id="nc8ni"><button id="nc8ni"></button><ins id="nc8ni"><button id="nc8ni"><form id="nc8ni"></form></button></ins>
<button id="nc8ni"><form id="nc8ni"></form></button>
<form id="nc8ni"><xmp id="nc8ni">
<ins id="nc8ni"><button id="nc8ni"></button></ins>
<button id="nc8ni"><xmp id="nc8ni">
<ins id="nc8ni"><form id="nc8ni"><ins id="nc8ni"></ins></form></ins>
<button id="nc8ni"><xmp id="nc8ni">
<button id="nc8ni"><xmp id="nc8ni">
<button id="nc8ni"><form id="nc8ni"><ins id="nc8ni"></ins></form></button><button id="nc8ni"><form id="nc8ni"></form></button>
<button id="nc8ni"><form id="nc8ni"><ins id="nc8ni"></ins></form></button><button id="nc8ni"><xmp id="nc8ni"><button id="nc8ni"></button><form id="nc8ni"><ins id="nc8ni"><form id="nc8ni"></form></ins></form><button id="nc8ni"><xmp id="nc8ni"><ins id="nc8ni"></ins>
<button id="nc8ni"><xmp id="nc8ni"><ins id="nc8ni"></ins><form id="nc8ni"><ins id="nc8ni"><form id="nc8ni"></form></ins></form>
<ins id="nc8ni"><form id="nc8ni"></form></ins>
<button id="nc8ni"><form id="nc8ni"><ins id="nc8ni"></ins></form></button>
<button id="nc8ni"></button>
<button id="nc8ni"></button>