http://www.cnblogs.com/bienfantaisie/archive/2011/05/27/2059597.html

清除浮动是连续浮动元素之后的必备工作,在工作中我做到需要清除浮动的地方都要清除。

比如,我在瑞星的项目中一直这样使用:

.clear:after{content:'\0020';display:block;height:0;clear:both}
.clear{*zoom:1}

观察腾讯微博项目,并不是每个浮动必须清除,但是如果内部元素连续浮动,其外部元素必然定高以避免找不到高度的情况,其清除浮动的代码如下:

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

腾讯微博的.clear和许多选择器并列在一起,如:

.clear,.LC,.topicList,.mediaWrap,.cellMod{zoom:1}

我和腾讯微博的技术总监聊过这里可以去掉.LC等其余的选择器,并在这些类上定义clear的类,这个问题肯定是遗留的,不过对性能没有影响。瑞星一个老资历的前端说是尽量减小html文件,这些大小可以作为代价转移到css文件上,不过我个人觉得css简洁一些,方法统一一些也是好事。

比较瑞星和腾讯的清除浮动的代码,有一些地方是不一样的,我在做瑞星的项目时,一开始采用的也是和腾讯一样的办法,在连续浮动元素后面追加'.',这样一来,页面中会出现大量的'.'字符,所以这种办法一定要定义visibility:hidden的属性。现在的瑞星项目采用的办法是在连续浮动元素后面追加空格(\0020),这样就不需要visibility和line-height属性,因空格在页面中是不可见的,而且html代码中的单个空格对页面显示并不会产生影响。在zoom:1的定义上,瑞星的定义只针对了会出问题的IE7和IE6浏览器,腾讯的代码针对所有浏览器,这里腾讯的代码可能在浏览器针对性上不如瑞星的代码。当然也有可能是为了更多浏览器的兼容,而我还没有研究到。

#1楼 2011-05-27 11:00 于安 
学习了: content
还有 .clear:after的写法, 这对应是怎么使用?

#2楼[楼主] 2011-05-27 11:06 BennyChia 

@于安
:after伪类受ie8以上支持,简单说就是在元素之后追加内容,需要和content属性一起使用,有点像jQuery里面的append()方法

#3楼 2011-05-27 12:03 Gray Zhang 

把.LC等全去掉,语义性会破坏得更加厉害,那这个class是不是干脆也别叫clear了,直接叫zoom-fix更好一点?
zoom这东西本来就是IE专有,且基本没有副作用,其他浏览器一概不认,所以加不加*其实无所谓,不需要担心未来的CSS会有zoom这属性,因为缩放已经被css3 transform实现了

#4楼 2011-05-27 13:09 code_flyer 

呵呵,这种技术很普遍的,来源于国外的clearfix 技术。
http://www.webtoolkit.info/css-clearfix.html

#5楼 2011-05-27 13:20 yonghu86 

值得推荐。

#6楼 2011-05-27 14:51 Jiyp 

:after伪类ie7也支持,请博主修正。另外问个问题:zoom:1 ,可以清理ie6的浮动么?我试了一下,怎么不好使呢

#7楼[楼主] 2011-05-27 15:03 BennyChia 

zoom:1不是用来清除浮动的,它是配合上面的:after来让ie6和7找到容器自身高度的

#8楼 2011-05-27 20:19 Gray Zhang 

@BENNY CHIA
IE6根本不认:after,zoom是为了触发hasLayout的,有了hasLayout的元素自动就有清浮动的特性

#9楼 2011-05-28 10:22 Jiyp 

@Gray Zhang
根据你的意思,那是不是可以理解为:在ie6下,让元素hasLayout,也就是变向的清楚浮动了?

#10楼 2011-05-28 11:26 Loveyuki 

一直用 .clear {clear:both; overflow:hidden; zoom:1; }

#11楼 2011-06-02 10:27 632611768 

学习了,哈哈..

#12楼 2011-06-02 10:56 Gray Zhang 

@Jiyp
IE下hasLayout的元素有很多特性,清浮动是其中之一,另外还有可设置width/height等其他效果

#13楼 2011-06-02 13:14 Lecaf 

我觉的overflow:hidden最好也加上,比较IE6的最小高度bug

#14楼 2012-12-24 15:43 semanwmj 

zoom:1有用吗?我怎么感觉加和不加一样啊

#15楼[楼主] 2012-12-24 16:03 BennyChia 

@semanwmj
在ie中zoom:1可以触发haslayout,IE中是有用的:)

#16楼 2012-12-24 16:34 semanwmj 

@BennyChia
可是触发和不触发也没看到有什么区别呀?

细微之处:比较两种CSS清除浮动的兼容的更多相关文章

  1. 8种CSS清除浮动的方法优缺点分析

    为什么清除CSS浮动这么难? 因为浮动会使当前标签产生向上浮的效果,同时会影响到前后标签.父级标签的位置及 width height 属性.而且同样的代码,在各种浏览器中显示效果也有可能不相同,这样让 ...

  2. css清除浮动大全共8种方法

    原文链接http://www.jb51.net/css/173023.html 清除浮动是每一个 web前台设计师必须掌握的机能.css清除浮动大全,共8种方法. 浮动会使当前标签产生向上浮的效果,同 ...

  3. CSS清除浮动八种方法

    在各种浏览器中显示效果也有可能不相同,这样让清除浮动更难了,下面总结8种清除浮动的方法,测试已通过 ie chrome firefox opera,需要的朋友可以参考下 清除浮动是每一个 web前台设 ...

  4. 【转】css清除浮动float的三种方法总结,为什么清浮动?浮动会有那些影响?

    摘要: css清除浮动float的三种方法总结,为什么清浮动?浮动会有那些影响?     一.抛一块问题砖(display: block)先看现象: 分析HTML代码结构: <div class ...

  5. CSS清除浮动大全的8种方法

    清除浮动是每一个 web前台设计师必须掌握的机能.css清除浮动大全,共8种方法. 浮动会使当前标签产生向上浮的效果,同时会影响到前后标签.父级标签的位置及 width height 属性.而且同样的 ...

  6. css清除浮动float的几种方法

    摘要: css清除浮动float的三种方法总结,为什么清浮动?浮动会有那些影响?     一.抛一块问题砖(display: block)先看现象: 这里我没有给最外层的DIV.outer 设置高度, ...

  7. 活学活用,CSS清除浮动的4种方法

    清除浮动这个问题,做前端的应该再熟悉不过了,咱是个新人,所以还是记个笔记,做个积累,努力学习向大神靠近. CSS清除浮动的方法网上一搜,大概有N多种,用过几种,说下个人感受. 1.结尾处加空div标签 ...

  8. CSS 清除浮动的4种方法

    此为未清除浮动源代码,运行代码无法查看到父级元素浅黄色背景.<style type=”text/css”> <!– *{margin:0;padding:0;} body{font: ...

  9. css清除浮动的八大方法

    清除浮动是每一个 web前台设计师必须掌握的机能.css清除浮动大全,共8种方法. 浮动会使当前标签产生向上浮的效果,同时会影响到前后标签.父级标签的位置及 width height 属性.而且同样的 ...

随机推荐

  1. 配置ipvsadm服务

    LVS的三种包转发方式      LVS提供了三种包转发方式:NAT(网络地址映射).IP Tunneling(IP隧道).Direct Routing(直接路由)     不同的转发模式决定了不同的 ...

  2. 集群之LVS(负载均衡)详解

    提高服务器响应能力的方法 scale on  在原有服务器的基础上进行升级或者直接换一台新的性能更高的服务器. scale out  横向扩展,将多台服务器并发向外响应客户端的请求.优点:成本低,扩展 ...

  3. 每天一个linux命令(12):head 命令

    head 与 tail 就像它的名字一样的浅显易懂,它是用来显示开头或结尾某个数量的文字区块,head 用来显示档案的开头至标准输出中,而 tail 想当然尔就是看档案的结尾. 1.命令格式: hea ...

  4. Ibatis学习总结3--SQL Map XML 映射文件

    在前面的例子中,只使用了 SQL Map 最简单的形式.SQL Map 的结构中还有其他更多 的选项.这里是一个 mapped statement 较复杂的例子,使用了更多的特性. <sqlMa ...

  5. HYSBZ 1269文本编辑器 splay

    比较基本的操作. #include<map> #include<queue> #include<stack> #include<cmath> #incl ...

  6. 【CodeForces 599A】D - 特别水的题4- Patrick and Shopping

    Description  meter long road between his house and the first shop and a d2 meter long road between h ...

  7. 【HDU 2160】母猪的故事

    题 Description 话说现在猪肉价格这么贵,著名的ACBoy 0068 也开始了养猪生活.说来也奇怪,他养的猪一出生第二天开始就能每天中午生一只小猪,而且生下来的竟然都是母猪. 不过光生小猪也 ...

  8. 【转】getHibernateTemplate出现的所有find方法的总结

    一.find(String queryString); 示例:this.getHibernateTemplate().find("from bean.User"); 返回所有Use ...

  9. BZOJ1046 [HAOI2007]上升序列

    Description 对于一个给定的S={a1,a2,a3,…,an},若有P={ax1,ax2,ax3,…,axm},满足(x1 < x2 < … < xm)且( ax1 < ...

  10. Windows Server 2008 显示桌面图标

    相信有朋友们有安装使用过windows 2008 server服务器,刚安装好的时候,桌面上只有一个回收站的图标,它没有像windows 7或windows 8一样可以直接通过右击鼠标的菜单来设置,要 ...