發(fā)文章
發(fā)文工具
撰寫
網(wǎng)文摘手
文檔
視頻
思維導(dǎo)圖
隨筆
相冊
原創(chuàng)同步助手
其他工具
圖片轉(zhuǎn)文字
文件清理
AI助手
留言交流
按照CSS規(guī)范,浮動(dòng)元素(floats)會(huì)被移出文檔流,不會(huì)影響到塊狀盒子的布局而只會(huì)影響內(nèi)聯(lián)盒子(通常是文本)的排列。因此當(dāng)其高度超出包含容器時(shí),一般父容器不會(huì)自動(dò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自然又是不支持的,所以這種方法和上一種方法一樣都對 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è)“塊級格式化范圍”——這是CSS 規(guī)范中提到的一種現(xiàn)象,它往往具有某種獨(dú)立性,特性之一就是會(huì)自動(dòng)閉合內(nèi)部的浮動(dòng)元素。 按照規(guī)范,以下類型的元素會(huì)產(chǎn)生一個(gè)塊級格式化范圍: ● 浮動(dòng)元素,left 或者 right 皆可。 ● 絕對定位的元素。 ● inline-block 元素,不過這個(gè) gecko目前不支持。 ● table-cell 類型元素,其實(shí) table, table-head-group, table-row 什么的也都可以,還有inline-table(gecko不支持)也同樣,因為他們都會(huì)間接產(chǎn)生一個(gè)匿名的 table-cell。 ● overflow 取值非 visible 的元素。 所以,原來在標(biāo)準(zhǔn)兼容瀏覽器中我們也可以有這么多的方法閉合一個(gè)浮動(dòng)元素,而且只需要 CSS,無需其他。順帶說一下以上除了overflow,其余都有一個(gè)附加效果就是自動(dòng)收縮父容器寬度。 而對于 IE/Win,它有一套自己的體系,就是 layout,具有 layout 的元素會(huì)自動(dòng)閉合浮動(dòng)元素,再來看看觸發(fā) layout 的 CSS 屬性,發(fā)現(xiàn)和上面的塊級格式化范圍有很多類似之處: ● 浮動(dòng)元素 ● 絕對定位元素 ● display:inline-block ● zoom ● width/height ● overflow/overflow-x/overflow-y [IE7 新增] ● max/min-width/height [IE7 新增] 網(wǎng)頁教學(xué)網(wǎng) 以上來看 IE 中閉合浮動(dòng)元素的方法也不少,自然也都有其局限性,要么有附帶效果,要么使用的是非標(biāo)準(zhǔn)屬性(無法通過驗(yàn)證)。 還要提一點(diǎn)的是 display:inline-block,這個(gè)屬性對 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 的方法:.gainlayout{display:inline-block;}.gainlayout{display:block;} 所以要跨瀏覽器閉合浮動(dòng)元素,可以選擇的方式還是很多的,如何搭配使用這些 CSS 屬性就要具體情況具體分析了,靈活應(yīng)用條件注釋也很有必要,要是實(shí)在不行我們回過頭來還有 clear 可以用嘛。
來自: WindySky > 《CSS》
0條評論
發(fā)表
請遵守用戶 評論公約
子元素浮動(dòng)父容器高度不能自適應(yīng)的CSS解決方法
子元素浮動(dòng)父容器高度不能自適應(yīng)的CSS解決方法。網(wǎng)頁前端工作者經(jīng)常會(huì)遇到子元素設(shè)置float浮動(dòng)后導(dǎo)致父容器高度不能自適應(yīng),也就是俗稱的外部容器不能被“撐大”,常見表現(xiàn)為背景或邊框異常,這時(shí)我們...
清理浮動(dòng)的幾種方法以及對應(yīng)規(guī)范說明
但是,由于浮動(dòng)特性,容器如果沒有明確設(shè)定高度,會(huì)依照普通流內(nèi)元素高度設(shè)置,這樣就會(huì)導(dǎo)致脫離普通流的浮動(dòng)元素溢出容器,影響其后元素布局。這樣,父容器高度未設(shè)定(值是 auto)時(shí),由于定義的清理浮...
讓DIV設(shè)置Float后高度不自動(dòng)增加
讓DIV設(shè)置Float后高度不自動(dòng)增加 本來想把這個(gè)題目修改為“閉合浮動(dòng)元素”或“清除浮動(dòng)元素”,但想了一下,還是不修改為好。這種方法就是向父容器的末尾再插入一個(gè)額外的標(biāo)簽,并令其清除浮動(dòng)(cl...
那些年我們一起清除過的浮動(dòng)
浮動(dòng)框不屬于文檔中的普通流,當(dāng)一個(gè)元素浮動(dòng)之后,不會(huì)影響到塊級框的布局而只會(huì)影響內(nèi)聯(lián)框(通常是文本)的排列,文檔中的普通流就會(huì)...
CSS清除浮動(dòng)專題
CSS清除浮動(dòng)專題CSS清除浮動(dòng)專題。網(wǎng)絡(luò)上流行的說法是:在非IE瀏覽器(如Firefox)下,當(dāng)容器的高度(height)為auto,且容器的內(nèi)容中有...
IE瀏覽器常見CSS兼容性問題及解決辦法
IE瀏覽器常見CSS兼容性問題及解決辦法?,F(xiàn)在市場上的IE瀏覽器主要有IE6、IE7、IE8、IE9、IE10、IE11等版本,IE5.5基本在市場上消失,所以后面的兼容性問題我們不做討論。/* 減號和下劃線是IE6專有的hac...
CSS Overflow屬性詳解
CSS Overflow屬性詳解。同樣有兩個(gè)overflow的姐妹屬性overflow-y 和overflow-x,它們很少被采用。如果你不設(shè)置overflow屬性,則默認(rèn)的ov...
!!!!!前端問題匯總
方法1:.outer{width:200px;height:200px;background:#000;filter:alpha(opacity=20);opacity:.2;}.inner{width:200px;height:200px;margin-top:-200px;}<div class="outer"></div&...
URL錨點(diǎn)HTML定位技術(shù)機(jī)制、應(yīng)用與問題 ? 張鑫旭
URL錨點(diǎn)HTML定位技術(shù)機(jī)制、應(yīng)用與問題 ?張鑫旭。也就是說,頁面之所以能定位到錨點(diǎn)所在位置,都是因?yàn)閁RL地址中的錨鏈的作用,而不是點(diǎn)...
微信掃碼,在手機(jī)上查看選中內(nèi)容