更簡潔的 CSS 清理浮動方式
2012/1/30 15:54:08

清理浮動有很多種方式,像使用 br 標簽自帶的 clear 屬,使用元素的 overflow,使用空標簽來設置 clear:both 等等。但考慮到兼容問題和語義化的問題,一般我們都會使用如下代碼來清理浮動。
/* 清理浮動 */
.clearfix:after { visibility:hidden; display:block; font-size:0; content:" "; clear:both; height:0;}
.clearfix { zoom:1;}
其原理是,在「高級」瀏覽器中使用 :after 偽類在浮動塊后面加上一個非 display:none 的不可見塊狀內容來,并給它設置 clear:both 來清理浮動。在 ie6 和 7 中給浮動塊添加 haslayout 來讓浮動塊撐高并正常影響文檔流。
上面的代碼應該是現在主流的清理浮動方式。現在支付寶就使用這樣的方式。而現在,Nicolas Gallagher 給出了一個更簡潔的方案:
.cf:before, .cf:after { content:"";  display:table;}
.cf:after { clear:both;}
.cf { zoom:1;}
原理還是一樣的。使用 :after 偽類來提供浮動塊后的 clear:both。不同的是,隱藏這個空白使用的是 display: table。而不是設置 visibility:hidden;height:0;font-size:0; 這樣的 hack。
值得注意的是這里中的 :before 偽類。其實他是來用處理 top-margin 邊折疊的,跟清理浮動沒有多大的關系。但因為浮動會創建 block formatting context,這樣浮動元素上的另而一元素上如果剛好有 margin-bottom 而這個浮動元素剛好有margin-top 的話,應該讓他們不折疊(雖然這種情況并不常見)。

返回列表
返回首頁 主站蜘蛛池模板: 天天躁日日躁狠狠躁日日躁| 本子库里番acg全彩无遮挡 | 久久777国产线看观看精品| 欧美人与性动交α欧美精品| 亚洲黄色三级视频| 美女爽到尿喷出来| 国产做床爱无遮挡免费视频| 日本三级韩国三级欧美三级| 国产香蕉国产精品偷在线| www.亚洲日本| 扁豆传媒视频免费观看| 久久精品国产69国产精品亚洲| 欧美人与牲动交a欧美精品| 亚洲麻豆精品果冻传媒| 精品久久久中文字幕二区| 四虎成人免费网址在线| 香蕉啪视频在线观看视频久| 国产欧美精品一区二区三区-老狼 国产欧美精品一区二区三区-老狼 | 久久久精品免费| 最近中文国语字幕在线播放| 亚洲成人黄色在线观看| 激情五月婷婷色| 伊人久久大香线蕉综合爱婷婷 | 国产午夜亚洲精品不卡免下载 | 知乎的小说哪里可以免费| 吃奶摸下高潮60分钟免费视频| 西西www人体高清视频在线观看| 国产成年无码久久久免费| 两个人看的www免费视频| 国产综合精品在线| 99久久综合精品国产| 天天天天躁天天爱天天碰2018| 一二三四在线观看免费高清视频| 成人性生交大片免费看午夜a| 久久久2019精品| 日本精品啪啪一区二区三区| 久久精品女人天堂AV麻| 日韩网新片免费| 亚洲av午夜福利精品一区| 欧美亚洲国产片在线播放| 亚洲国产美女福利直播秀一区二区|