伦理片hd-伦理片 在线播放-伦理片 在线-伦理免费在线观看-综合图片区-综合婷婷

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

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

網絡 2008/6/29 20:45:46 深山行者 字體: 瀏覽 6604

按照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可以用嘛。

相關閱讀
access數據庫做的網站出現.ldb不能刪除超過2KB之后就會網站訪問不了數據庫,提示數據庫不存在
后臺編輯源碼里有行號
jquery中動態生成的代碼使用on hover事件時不出現效果
純div+css制作的彈出菜單-02
19寸寬屏旅行社網站默認模板
圖片上傳時,如果格式不正確,跳出警告
網站完成各個瀏覽器兼容測試
留言板留言板V7.0
共有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還有其它的嗎
更多>>隨機抽取信息
越獄ios老應用老游戲合集下載
19寸寬屏旅行社網站模板7
shopify廣告與Facebook廣告操作
CSS設計網頁頭部的優化寫法
連云港五洲旅行社有限公司
深山行者留言系統V3.1
主站蜘蛛池模板: 欧美激情一区二区三区视频 | 欧美日操| 天天色综合2| 麻豆成人精品国产免费 | 久久99热这里只有精品国产 | 男女福利视频 | 久热这里有精品 | 火影忍者纲f手黄漫acg | 日产精品卡二卡三卡四卡乱码视频 | 日韩欧美一区二区三区免费看 | 国家免费看在线视频 | 中文字幕国产一区 | 国产区一二三四区2021 | 成人午夜兔费观看网站 | 国产中文字幕免费 | 亚洲三级在线观看 | 亚洲精品视频免费观看 | 妹天堂在线观看 | 国产中文字幕在线免费观看 | 办公室被老板调教bd | 色综合天天综合给合国产 | 免费不卡 | 亚洲综合激情网 | 91麻豆免费视频 | 国产一二三四区在线观看 | 向日葵视频在线免费观看 | 亚洲噜噜噜噜噜影院在线播放 | 天天干天天干天天插 | 大胖子h粗污 | 窝窝社区在线观看www | 亚洲综合影院 | 国产1024精品视频专区免费 | 欧美综合第一页 | 在线观看亚洲天堂 | 免费在线欧美 | 青青青在线视频播放免费 | 可以免费看污片的网站 | 久久精品伊人网 | 91精品国产免费久久 | 亚洲精品欧美精品中文字幕 | 国产亚洲一区二区三区在线 |