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