当前位置: 首页 > 图文教程 > 网页制作 > CSS样式表 > 再论清除浮动的空DIV方法

CSS样式表
HTML中的数据绑定
CSS定义通用透明效果
一段巧妙的css debug代码
布局遇到的问题 非常不错的见解
利用CSS控制SELECT中的OPTION是否不允许选
CSS也能控制表格的交替颜色
CSS之自动换行
IE7 beta2的CSS兼容性
学习Xhtml+CSS2的一些心得体会
网页设计中色彩搭配的内涵
表格边框的css语法
让comment标记在各浏览器都能通用
标准化——表格
IE图片下空隙问题解决方法集合
用DIV+CSS如何实现这种表格效果
相对路径与绝对路径的区别
关于居中布局和IE双倍边距bug
块元素block element和内联元素inline element
CSS做一个超链接的陷下效果
图片翻转菜单技术研究

CSS样式表 中的 再论清除浮动的空DIV方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2010-03-17   浏览: 181 ::
收藏到网摘: n/a

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 中插入没有语义的容器,未免有些突兀。