CSS 使用浮动会造成布局的混乱,通常清除浮动的方法是,利用一个如下样式的空 Div:
div class="clear"/div.clear{clear:both;}
更为优良的 CSS 代码是:
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/).clear:after{content:".";display:block;height:0;clear:both;visibility:hidden;}.clear{zoom:1;}
这个方法目前已经广泛使用,淘宝、口碑,都是这种用法。通过 after 伪类 :after 和 针对 IE6 的独立 CSS Hack 来实现,完全兼容主流浏览器。
当然,这在通过 CSS 在元素之后追加 "." 并不必要,因为还需要 visibility 来隐藏掉它。通过优化,代码如下:
(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/).clear:after{content:"020";display:block;height:0;clear:both;}.clear{zoom:1;}
其中,020 指在容器后添加空格,这样就避免使用 visibility 隐藏可视性了。
另外,不推荐使用空 div 的方法。单单为了清除浮动而在结构良好的 HTML 中插入没有语义的容器,未免有些突兀。