IE6的浮动float时3px问题
来源:广州中睿信息技术有限公司官网
发布时间:2012/10/21 23:25:16 编辑:editor 阅读 371
IE6和更早的版本会在一个浮动的列(橙色)和一个非浮动的列(灰色)之间插入一个3px的空间。这个3px空间的准确位置取决于几个条件。非浮动列没有固定的宽度或者高度。非浮动列有固定的宽度或者高度。当满

 

IE6和更早的版本会在一个浮动的列(橙色)和一个非浮动的列(灰色)之间插入一个3px的空间。这个3px空间的准确位置取决于几个条件。

  1. 非浮动列没有固定的宽度或者高度。
  2. 非浮动列有固定的宽度或者高度。

当满足第1种条件时,非浮动列里会沿着浮动列有个3px的缩进,直到浮动终止(如下图,注意在灰色的左边有3px的空间)。 
3px

如果要修复这个BUG,要完成两个步骤。

第一步,给非浮动列一个高度(height: 1px)。当完成这个步骤时,就满足了上面所说的第2个条件,非浮动列有固定的宽度或高度。这时3px的空间会出现在浮动列与非浮动列的中间,而不是非浮动列的里面(如下图,注意在橙色与灰色的交界处有3px的空间)。有的时候因为这3px的原因,会把灰色的列挤到橙色的列下面。 
3px

第二步,调整非浮动列的margin-left为0,然后调整浮动列的margin-right为-3px,将非浮动列拉回正确的位置。

经过上面两步的操作,这两个列在IE6下就能正确的显示了。然后用CSS hack的方法管理针对IE6的样式,确保所以浏览器显示正常。

代码示例:

 

 

 

 

 

 

联系我们CONTACT 扫一扫
愿景:成为最专业的软件研发服务领航者
中睿信息技术有限公司 广州•深圳 Tel:020-38931912 务实 Pragmatic
广州:广州市天河区翰景路1号金星大厦18层中睿信息 Fax:020-38931912 专业 Professional
深圳:深圳市福田区车公庙有色金属大厦509~510 Tel:0755-25855012 诚信 Integrity
所有权声明:PMI, PMP, Project Management Professional, PMI-ACP, PMI-PBA和PMBOK是项目管理协会(Project Management Institute, Inc.)的注册标志。
版权所有:广州中睿信息技术有限公司 粤ICP备13082838号-2