欧美一级特黄大片做受成人-亚洲成人一区二区电影-激情熟女一区二区三区-日韩专区欧美专区国产专区

CSS規(guī)范-元素閉合與浮動

2024-03-17    分類: 網(wǎng)站建設

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

有一種做法就是在父容器內(nèi)再插入一個額外的標簽,并令其清除浮動(clear)以撐大父容器。這種方法瀏覽器兼容性好,沒有什么問題,缺點就是需要 額外的(而且通常是無語義的)標簽,所以我個人不大喜歡。后來又有了一種新的方式,使用 :after 偽類動態(tài)的嵌入一個用于清除浮動的元素,這種方法和上一種原理一樣,不同的只是把這個額外的內(nèi)容用 CSS 生成,但考慮到 IE 不支持 :after 不得不做了不少的 hack。這種方法兼容性一般,但經(jīng)過各種 hack 也可以應付不同瀏覽器了,同時又可以保證 html 比較干凈,所以用得還是比較多的。再后來又有人發(fā)現(xiàn)將父容器的 overflow 設為除 visible 之外的值就可以在標準兼容瀏覽器中閉合浮動元素,IE自然又是不支持的,所以這種方法和上一種方法一樣都對 IE 做了不同處理(具體就是觸發(fā)layout),不同的就是overflow 沒有 :after 偽類那么麻煩了,缺點也有,overflow 可能會產(chǎn)生一些小沖突。在使用 overflow 之前還有過一種使用 float 的方法,就是讓父容器也浮動,這利用到了浮動元素的一個特性——浮動元素會閉合浮動元素。這種方式在 IE/Win 和標準兼容瀏覽器中都有較好的效果,但缺點也很明顯——父容器未必想浮動就浮動的了,畢竟浮動是一種比較特殊的行為,有時布局不允許其浮動也很正常。使用 float 雖然在 IE 和標準兼容瀏覽器中都能閉合浮動元素,但原理卻是不同的,IE/Win 中 float 觸發(fā)了 layout 因而閉合了浮動,而在標準兼容瀏覽器中,float 其實和上一種方法中的 overflow 原理一樣,產(chǎn)生了一個“塊級格式化范圍”——這是CSS 規(guī)范中提到的一種現(xiàn)象,它往往具有某種獨立性,特性之一就是會自動閉合內(nèi)部的浮動元素。

按照規(guī)范,以下類型的元素會產(chǎn)生一個塊級格式化范圍:

浮動元素,left 或者 right 皆可。 絕對定位的元素。 inline-block 元素,不過這個 gecko目前不支持。 table-cell 類型元素,其實 table, table-head-group, table-row 什么的也都可以,還有inline-table(gecko不支持)也同樣,因為他們都會間接產(chǎn)生一個匿名的 table-cell。 overflow 取值非 visible 的元素。 所以,原來在標準兼容瀏覽器中我們也可以有這么多的方法閉合一個浮動元素,而且只需要 CSS,無需其他。順帶說一下以上除了overflow,其余都有一個附加效果就是自動收縮父容器寬度。

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

浮動元素 絕對定位元素 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 不會消失,同時也不會影響其他瀏覽器,所以目前來說,這也算一個不錯的觸發(fā) layout 的方法:

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

文章標題:CSS規(guī)范-元素閉合與浮動
文章URL:http://aaarwkj.com/news34/320534.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供搜索引擎優(yōu)化、網(wǎng)站設計公司、服務器托管、營銷型網(wǎng)站建設網(wǎng)站排名、建站公司

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

外貿(mào)網(wǎng)站制作
亚洲一区精品二人人爽久久| 欧美亚洲一区二区三区精品| 久久亚洲精品中文字幕馆| 性生活真实视频免费看| 性色av人妻中文一区二区| 国产女主播精品视频一区| 国产视频一区二区麻豆| 亚洲精品一区二区三区中文字幕| 国产91美女黄色在线观看| 国产高清在线a视频大全| 国产熟女肥臀精品国产馆乱| 九九久久亚洲av成人乱片| 欧美日韩国产成人一区| 欧美日韩精品福利一区二区| 九色综合狠狠综合久久| 青青草原免费在线观看| 亚洲精品国产熟女av| 久久精品一区欧美成人| 国产精品_国产精品_k频道| 国产精品一区二在线观看| 亚洲二区三区四区在线| 无遮挡无掩盖的免费网站| av中文字幕乱码在线看| 亚洲av不卡一区二区在线观看| 很色很污无遮挡的网色污| 亚洲午夜精品美女写真| 天天操天天干夜夜射| 四虎免费在线视频观看| 色噜噜人妻av中文字幕| av免费在线观看麻豆| 亚洲欧美一区二区三区三| 加勒比在线观看欧美一区| 熟女自拍偷拍视频播放| 婷婷丁香久久五月婷婷| 亚洲国产成人久久综合区| 四虎在线永久观看视频| 亚洲一区二区三区日韩精品| 亚洲av污精品一区二区三区| 国产自拍免费在线观看视频| 国产在线不卡中文字幕| 粉嫩国产精品一区二区|