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

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

CSS教程:弄懂閉合浮動元素

網頁教學網 2008/4/26 22:56:59 深山行者 字體: 瀏覽 6157

按照CSS規范,浮動元素(floats)會被移出文檔流,不會影響到塊狀盒子的布局而只會影響內聯盒子(通常是文本)的排列。因此當其高度超出包含容器時,一般父容器不會自動伸長以閉合浮動元素。但是有時我們卻需要這種自動閉合行為,具體如何處理呢?

有一種做法就是在父容器內再插入一個額外的標簽,并令其清除浮動(clear)以撐大父容器。這種方法瀏覽器兼容性好,沒有什么問題,缺點就是需要額外的(而且通常是無語義的)標簽,所以我個人不大喜歡。

后來又有了一種新的方式,使用 :after 偽類動態的嵌入一個用于清除浮動的元素,這種方法和上一種原理一樣,不同的只是把這個額外的內容用 CSS 生成,但考慮到 IE 不支持 :after 不得不做了不少的 hack。這種方法兼容性一般,但經過各種 hack 也可以應付不同瀏覽器了,同時又可以保證 html 比較干凈,所以用得還是比較多的。

再后來又有人發現將父容器的 overflow 設為除 visible 之外的值就可以在標準兼容瀏覽器中閉合浮動元素,IE自然又是不支持的,所以這種方法和上一種方法一樣都對 IE 做了不同處理(具體就是觸發layout),不同的就是overflow 沒有 :after 偽類那么麻煩了,缺點也有,overflow 可能會產生一些小沖突。

在使用 overflow 之前還有過一種使用 float 的方法,就是讓父容器也浮動,這利用到了浮動元素的一個特性——浮動元素會閉合浮動元素。這種方式在 IE/Win 和標準兼容瀏覽器中都有較好的效果,但缺點也很明顯——父容器未必想浮動就浮動的了,畢竟浮動是一種比較特殊的行為,有時布局不允許其浮動也很正常。使用 float 雖然在 IE 和標準兼容瀏覽器中都能閉合浮動元素,但原理卻是不同的,IE/Win 中 float 觸發了 layout 因而閉合了浮動,而在標準兼容瀏覽器中,float 其實和上一種方法中的 overflow 原理一樣,產生了一個“塊級格式化范圍”——這是CSS 規范中提到的一種現象,它往往具有某種獨立性,特性之一就是會自動閉合內部的浮動元素。

按照規范,以下類型的元素會產生一個塊級格式化范圍:


● 浮動元素,left 或者 right 皆可。
● 絕對定位的元素。
● inline-block 元素,不過這個 gecko目前不支持。
● table-cell 類型元素,其實 table, table-head-group, table-row 什么的也都可以,還有inline-table(gecko不支持)也同樣,因為他們都會間接產生一個匿名的 table-cell。
● overflow 取值非 visible 的元素。

所以,原來在標準兼容瀏覽器中我們也可以有這么多的方法閉合一個浮動元素,而且只需要 CSS,無需其他。順帶說一下以上除了overflow,其余都有一個附加效果就是自動收縮父容器寬度。

而對于 IE/Win,它有一套自己的體系,就是 layout,具有 layout 的元素會自動閉合浮動元素,再來看看觸發 layout 的 CSS 屬性,會發現和上面的塊級格式化范圍有很多類似之處:


● 浮動元素
● 絕對定位元素
● display:inline-block
● zoom
● width/height
● overflow/overflow-x/overflow-y [IE7 新增]
● max/min-width/height [IE7 新增]

以上來看 IE 中閉合浮動元素的方法也不少,自然也都有其局限性,要么有附帶效果,要么使用的是非標準屬性(無法通過驗證)。

還要提一點的是 display:inline-block,這個屬性對 IE 而言本身沒什么用,實際效果只是給一個元素暗地添加了 layout,但是標準兼容瀏覽器是認得這個屬性的,所以要不影響這些瀏覽器,需要將 display 設回默認。這里 IE 有一個 bug,如果先定義了 display:inline-block,然后再將 display 設回 block(這兩個 display 要先后放在兩個 CSS 聲明中才有效果),那么 layout 不會消失,同時也不會影響其他瀏覽器,所以目前來說,這也算一個不錯的觸發 layout 的方法:

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

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

相關閱讀
最新縣及縣以上1980年以來歷史行政區劃代碼大全截止2018年3月31日
旅行社網站模板默認風格2
北京青年旅行社股份有限公司
倒計時廣告/始終保持在網頁中部
160個DIV+CSS網頁模板下載
一個select表單移處數據的效果,非常好用。
隨心所欲的定制彈出窗口
div+CSS的無限級擴展下拉菜單(全部加了注釋)
共有0條關于《CSS教程:弄懂閉合浮動元素》的評論
發表評論
正在加載評論......
返回頂部發表評論
呢 稱:
表 情:
內 容:
評論內容:不能超過 1000 字,需審核,請自覺遵守互聯網相關政策法規。
驗證碼: 驗證碼 
網友評論聲明,請自覺遵守互聯網相關政策法規。

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

更多信息>>欄目類別選擇
百度小程序開發
微信小程序開發
微信公眾號開發
uni-app
asp函數庫
ASP
DIV+CSS
HTML
python
更多>>同類信息
jquery設置或獲取修改classname
利用css3.0寫出一個音樂播放的唱片碟盤的效果
利用css中的scale()實現放大縮小效果
利用background-color:#000000a8在背景顏色16進制代碼之后加字母加上數字讓背景色透明
css背景使用base64編碼或者將base64編碼放在img圖片標簽中
利用css3中的-webkit-font-smoothing把網頁文字的毛邊去掉
更多>>最新添加文章
dw里面查找替換使用正則刪除sqlserver里面的CONSTRAINT
Android移動端自動化測試:使用UIAutomatorViewer與Selenium定位元素
抖音直播音掛載小雪花 懂車帝小程序
javascript獲取瀏覽器指紋可以用來做投票
火狐Mozilla Firefox出現:無法載入您的Firefox配置文件 它可能已經丟失 或是無法訪問 問題解決集合處理辦法
在Android、iOS、Windows、MacOS中微信小程序的文件存放路徑
python通過代碼修改pip下載源讓下載庫飛起
python里面requests.post返回的res.text還有其它的嗎
更多>>隨機抽取信息
詳談CSS設計中import與link的區別所在
四川悠旅地旅游有限公司
七種網站添加鏈接的簡單方法
JS壓縮
連云港華夏國際旅行社
深山行者個人網站程序V0.1
99热热热_国产成人自拍一区_欧美一级网站_99热在线播放_国产精品乱码一区二区三区_久久精品国产一区二区三区
  • <li id="6qmi0"></li>
  • <li id="6qmi0"><source id="6qmi0"></source></li>
    国产精品区一区二区三含羞草| 欧美激情第8页| 99视频在线精品国自产拍免费观看| 好吊色欧美一区二区三区视频 | 久久亚洲综合网| 欧美激情偷拍| 五月天综合网| 欧美日韩视频在线一区二区观看视频 | 亚洲美女网站| 欧美1区视频| 日本一区视频在线播放| 国产欧美日韩一区二区三区| 亚洲一区日本| 亚洲欧美国产精品桃花| 91久久久久| 国内一区二区三区| 国产精品99免费看| 欧美三区美女| 狠狠噜噜久久| 亚洲高清久久| 在线亚洲精品| 久久精品成人一区二区三区蜜臀| 亚洲精品乱码久久久久久蜜桃麻豆| 欧美日韩三区| 国产精品mm| 最新亚洲一区| 国产视频久久| 97se亚洲综合| 国产精品三区在线| 精品一区二区三区视频日产| 国产一区在线免费| 久久综合狠狠综合久久综青草| 国产精品免费一区二区三区在线观看 | 亚洲一区二区三区精品动漫| 亚洲三区在线观看| 国产精品videossex久久发布| 欧美日韩1080p| 亚洲大片av| 狂野欧美一区| 奇米精品在线| 欧美精品导航| 亚洲专区一区二区三区| 99久久伊人精品影院| 久久国产精品-国产精品| 欧洲亚洲一区二区三区四区五区| 婷婷五月色综合| 国产一区免费视频| 午夜一级久久| 免费一区二区三区在在线视频| 亚洲视频精品一区| 亚洲国产1区| av一本久道久久波多野结衣| 蜜桃成人在线| 欧美日韩一区二区三区免费| 午夜在线观看免费一区| 国产一区福利视频| 欧美69wwwcom| 美脚丝袜一区二区三区在线观看| 精品国产乱码久久久久久88av | 99热这里只有精品8| 国产精品日韩一区二区三区| 一区二区精品免费视频| 国产精品美女xx| 欧美一区亚洲二区| 亚洲东热激情| 裸模一区二区三区免费| 亚洲私拍自拍| 免费成人深夜夜行视频| 亚洲私人影院| 另类视频在线观看+1080p| 欧美日韩一区二区视频在线| 成人欧美一区二区| 欧美 日韩 国产 一区| 久久夜色精品| 欧美日韩一区在线播放| 福利视频一区二区三区| 午夜视频一区| 精品欧美国产一区二区三区不卡| 亚洲国产精品日韩| 欧美精品v日韩精品v国产精品| 一区二区三区国产盗摄| 久久波多野结衣| 亚洲欧美日韩一区在线观看| 一区二区91美女张开腿让人桶| 久久久蜜桃一区二区人| 国内综合精品午夜久久资源| 久久久一本精品99久久精品66| 亚洲综合三区| 国产综合久久| 先锋影音欧美| 精品亚洲第一| 狂野欧美一区| 亚洲一区三区视频在线观看| 中文字幕在线亚洲精品 | 国产精品分类| 亚洲 国产 日韩 综合一区| 久久综合久久久| 国产三区二区一区久久| 牛夜精品久久久久久久99黑人| 精品一区二区不卡| 91久色国产| 亚洲欧美日产图| 亚洲精品一区二区三区av| 中日韩在线视频| 欧美一区二区三区精美影视| 成人18视频| 老牛国产精品一区的观看方式| 亚洲清纯自拍| 亚洲福利电影| 国一区二区在线观看| 中文字幕乱码一区二区三区| 日本不卡一区二区三区在线观看| 久久精品国产精品青草色艺| 97av影视网在线观看| 久久精品一区二区国产| 国产乱码精品| 亚洲欧美日韩在线观看a三区| 一本一本久久a久久精品综合妖精| 好看的av在线不卡观看| 国产精品大全| 亚洲人妖在线| 国产日韩欧美三区| 国产日韩三区| 麻豆精品网站| 国产精品欧美久久| 国产日韩欧美亚洲一区| 国产一区在线免费| 免费精品视频一区二区三区| 欧美一区二区三区在线播放| 神马影院我不卡午夜| 亚洲精品第一区二区三区| 欧美影院一区| 亚洲麻豆视频| 99re在线| 欧美一区二区三区成人久久片| 视频一区免费观看| 欧美日韩国产成人精品| 亚洲久久视频| 99九九视频| 欧洲视频一区二区三区| 欧美在线二区| 国产亚洲精品久久飘花| 99精品欧美一区二区三区| 久久66热这里只有精品| 亚洲精品在线免费看| 欧美精品偷拍| 久久久久久久波多野高潮日日| 国产一级二级三级精品| 欧美精品欧美精品| 欧美日韩综合另类| 久久久精品五月天| 欧美成人一区二区在线| 欧美日韩天天操| 99国精产品一二二线| 欧美精品一区二区三区在线四季 | 久久久久久一区| 精品国产一区二区三| 午夜精品视频| 麻豆av福利av久久av| 欧美日韩亚洲在线| 亚洲特色特黄| 久久精品女人的天堂av| 欧美天天视频| 国内外成人免费视频| 狠狠色丁香久久综合频道| 老妇喷水一区二区三区| 一区二区不卡在线| 久久国产精品亚洲va麻豆| 日韩wuma| 久久久人人人| 午夜精品婷婷| 鲁鲁视频www一区二区| 一区二区在线不卡| 精品国产一区二区三区日日嗨| 影音先锋在线一区| 欧美精品一区二区三区久久| 亚洲美女毛片| 亚洲欧洲久久| 国产偷国产偷亚洲高清97cao| 欧美日韩在线观看一区二区三区| 国内成+人亚洲| 一二三区精品| 欧美精品激情| 女女同性女同一区二区三区91| 国产亚洲精品久久飘花| 亚洲电影一二三区| 国产精品一区二| 亚洲一区二区三区精品在线观看| 亚洲巨乳在线观看| 国内外成人免费视频| 国产婷婷精品| 欧美日韩99| 亚洲美女网站18| 麻豆传媒一区二区| 99国产在线| 美女尤物久久精品| 亚洲午夜一区| 国产精品成人观看视频免费| 欧美亚洲免费高清在线观看| 久久九九免费|