中文字幕在线一区二区在线,久久久精品免费观看国产,无码日日模日日碰夜夜爽,天堂av在线最新版在线,日韩美精品无码一本二本三本,麻豆精品三级国产国语,精品无码AⅤ片,国产区在线观看视频

      CSS閉合浮動元素教程

      時間:2024-06-26 02:04:00 CSS 我要投稿
      • 相關推薦

      CSS閉合浮動元素教程

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

      【CSS閉合浮動元素教程】相關文章:

      CSS入門教程01-25

      css屬性定位教程04-01

      CSS選擇器教程04-01

      CSS教程之盒模型04-01

      關于CSS教程:復合型條狀圖表01-25

      CSS基礎教程之背景圖片04-01

      CSS-層疊樣式表基礎教程03-05

      詳細解答CSS中相同元素不同結構重復定義的問題03-16

      CSS教程之重置默認樣式與IE兼容圓角的解決方法03-06

      主站蜘蛛池模板: 亚洲色图视频在线播放| 青青草视频在线观看视频网站| 蜜桃av区一区二区三| 国产女主播免费在线观看| 蜜桃伦理一区二区三区| 少妇被搞高潮在线免费观看| 亚洲国产精品免费一区| 三门峡市| 久久99久久99精品免观看不卡 | 欧美精品一本久久男人的天堂| 日韩精品中文字幕 一区| 久久夜精品综合缴情五月| 好看午夜一鲁一鲁一鲁| 丰满人妻无奈张开双腿av| 九龙城区| 国产性感丝袜美女av| 婷婷激情五月综合在线观看| 谁有在线观看av中文| 久久精品亚洲一区二区| 九一成人AV无码一区二区三区| 通化县| 桐城市| 翼城县| 国产美女a做受大片免费| 济源市| 精品理论一区二区三区| 昌平区| 被黑人操的嗷嗷叫视频| 一区二区丝袜美腿视频| 黄色大片一区二区中文字幕| 邯郸县| 亚洲国产精品久久久性色av| 一二三四中文字幕日韩乱码| 亚洲区一区二在线视频| 赤峰市| 国产性一交一乱一伦一色一情| av永久天堂一区二区三区蜜桃| 久久精品国产热久久精品国产亚洲| 韩国三级大全久久网站| 一本大道久久精品一本大道久久 | 久色精品国产亚洲av麻豆一|