99热热热_国产成人自拍一区_欧美一级网站_99热在线播放_国产精品乱码一区二区三区_久久精品国产一区二区三区

訂閱本欄目 RSS您所在的位置: 深山工作室 > DIV+CSS > 正文

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

網(wǎng)頁教學(xué)網(wǎng) 2008/4/26 22:56:59 深山行者 字體: 瀏覽 6036

按照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自然又是不支持的,所以這種方法和上一種方法一樣都對(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,具有 layout 的元素會(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 的方法:

.gainlayout{display:inline-block;}
.gainlayout{display:block;}

所以要跨瀏覽器閉合浮動(dòng)元素,可以選擇的方式還是很多的,如何搭配使用這些 CSS 屬性就要具體情況具體分析了,靈活應(yīng)用條件注釋也很有必要,要是實(shí)在不行我們回過頭來還有 clear 可以用嘛。

相關(guān)閱讀
詳談CSS設(shè)計(jì)中import與link的區(qū)別所在
jquery實(shí)現(xiàn)單選按鈕radio選中和取消 使用prop()代替attr()
購物時(shí)某件商品倒計(jì)時(shí)銷售非常不錯(cuò)
查詢某個(gè)字符在字符串中出現(xiàn)的位置數(shù)組
Visa簽證服務(wù)商建站解決方案
excel中End(xlUp)取活動(dòng)單元表的第一列最后一個(gè)有值的行號(hào)
防止網(wǎng)站內(nèi)容被人小偷和采集的ASP代碼
景點(diǎn)門票預(yù)訂商建站解決方案
共有0條關(guān)于《CSS教程:弄懂閉合浮動(dòng)元素》的評(píng)論
發(fā)表評(píng)論
正在加載評(píng)論......
返回頂部發(fā)表評(píng)論
呢 稱:
表 情:
內(nèi) 容:
評(píng)論內(nèi)容:不能超過 1000 字,需審核,請(qǐng)自覺遵守互聯(lián)網(wǎng)相關(guān)政策法規(guī)。
驗(yàn)證碼: 驗(yàn)證碼 
網(wǎng)友評(píng)論聲明,請(qǐng)自覺遵守互聯(lián)網(wǎng)相關(guān)政策法規(guī)。

您發(fā)布的評(píng)論即表示同意遵守以下條款:
一、不得利用本站危害國家安全、泄露國家秘密,不得侵犯國家、社會(huì)、集體和公民的合法權(quán)益;
二、不得發(fā)布國家法律、法規(guī)明令禁止的內(nèi)容;互相尊重,對(duì)自己在本站的言論和行為負(fù)責(zé);
三、本站對(duì)您所發(fā)布內(nèi)容擁有處置權(quán)。

更多信息>>欄目類別選擇
百度小程序開發(fā)
微信小程序開發(fā)
微信公眾號(hào)開發(fā)
uni-app
asp函數(shù)庫
ASP
DIV+CSS
HTML
python
更多>>同類信息
jquery設(shè)置或獲取修改classname
利用css3.0寫出一個(gè)音樂播放的唱片碟盤的效果
利用css中的scale()實(shí)現(xiàn)放大縮小效果
利用background-color:#000000a8在背景顏色16進(jìn)制代碼之后加字母加上數(shù)字讓背景色透明
css背景使用base64編碼或者將base64編碼放在img圖片標(biāo)簽中
利用css3中的-webkit-font-smoothing把網(wǎng)頁文字的毛邊去掉
更多>>最新添加文章
dw里面查找替換使用正則刪除sqlserver里面的CONSTRAINT
Android移動(dòng)端自動(dòng)化測(cè)試:使用UIAutomatorViewer與Selenium定位元素
抖音直播音掛載小雪花 懂車帝小程序
javascript獲取瀏覽器指紋可以用來做投票
火狐Mozilla Firefox出現(xiàn):無法載入您的Firefox配置文件 它可能已經(jīng)丟失 或是無法訪問 問題解決集合處理辦法
在Android、iOS、Windows、MacOS中微信小程序的文件存放路徑
python通過代碼修改pip下載源讓下載庫飛起
python里面requests.post返回的res.text還有其它的嗎
更多>>隨機(jī)抽取信息
IE6不支持png24的解決辦法(png24做為css的背景)
利用css制作簡易相冊(cè)
javascript正則的用法與示例
python里面requests.post返回的res.text還有其它的嗎
javascript根據(jù)內(nèi)容轉(zhuǎn)換為拼音
網(wǎng)頁鏈接十字顯示就像CAD十字做標(biāo)一樣,效果非常好
主站蜘蛛池模板: 国产剧情在线播放 | 欧美激情黄色 | 免费亚洲网站 | 亚洲欧美一区二区三区不卡 | 亚洲一区中文字幕 | 国产一区免费在线观看 | 国产精品入口免费视 | 2020阿v天堂网m | 插女人逼视频 | 久久丝袜脚交足黄网站免费 | 国产一区二区三区四区 | 亚洲成aⅴ人在线观看 | 成人在线观看小视频 | 久久精品视频8 | 在线视频日本 | 91视频在线观看 | 精品欧美一区二区精品久久 | 日日操狠狠干 | 又色又爽又大免费区欧美 | 一级淫片视频 | 久久夜夜| 二级特黄绝大片免费视频大片 | 国产成人精品一区二区三区 | 西西大胆午夜视频 | 亚洲精品www久久久久久 | 国产一区二区中文字幕 | 一级片视频免费 | 一区二区三区在线看 | 日本精品视频在线观看 | 国产一区二区在线看 | 国产伦精品一区二区三区在线 | 插插射啊爱视频日a级 | 成人免费视频视频在线观看 免费 | 黄色大片一区二区三区 | 日本一区二区三区网站 | 日韩在线观看一区二区 | 日韩一级在线播放 | 91视频久久久久 | 黄大全 | 中国特级黄色毛片 | 天天草天天摸 |