日期:2013-12-21  浏览次数:20946 次

网页制造aiyiweb文章简介:再论清除浮动的空DIV方法.

CSS 使用浮动会形成规划的混乱,通常清除浮动的方法是,利用一个如下款式的空 Div:

<div class="clear"></div>
.clear{clear:both;}

更为优秀的 CSS 代码是:

.clear:after{content:".";display:block;height:0;clear:both;visibility:hidden;}
.clear{zoom:1;}

这个方法目前曾经广泛使用,淘宝、口碑,都是这种用法。通过 after 伪类 :after 和 针对 IE6 的独立 CSS Hack 来实现,完全兼容主流浏览器。

当然,这在通过 CSS 在元素之后追加 "." 并不必要,由于还需求 visibility 来隐藏掉它。通过优化,代码如下:

.clear:after{content:"020";display:block;height:0;clear:both;}
.clear{zoom:1;}

其中,020 指在容器后添加空格,这样就避免使用 visibility 隐藏可视性了。

另外,不推荐使用空 div 的方法。单单为了清除浮动而在结构良好的 HTML 中插入没有语义的容器,不免有些突兀。