日期:2013-12-21 浏览次数:21026 次
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 中插入没有语义的容器,不免有些突兀。