修正IE6在HTML标准下出现bug的小技巧

开发 前端
随着大家对IE8浏览器越来越了解,发现IE8对CSS标准的支持的确有非常大的改观。这里我们总结了8个使用有效的HTML和CSS代码来修正网页在IE6下显示错位情况的解决方法。

在IE8发布不久之后,Opera首席执行官Jon von Tetzchner曾经对外公开表示,微软的IE8浏览器还会对网络标准继续破坏。不过随着大家对IE8浏览器越来越了解,发现IE8对CSS标准的支持的确有非常大的改观。

微软的IE8已采纳了万维网联合会的HTML 5和CSS2.1标准,只是还没有采用已使用于Mozilla,谷歌,和Opera浏览器的SVG。多年来面对W3C机构对HTML标准的开发停滞不前,微软便以自己的IE浏览器引擎建立了自己的网络标准。随着各大浏览器的快速发展,同时也推动了HTML标准向前发展。

从而使得IE浏览器独立开发这些标准属性跟HTML 5标准不太相符,这就扭曲了浏览器市场,迫使网站设计者建立的网页需要同时兼容于IE6,IE7,IE8和其他的浏览器。

既然外界的环境是WEB开发者无法改变的事情,那么我们只有加强自身的技能来适应目前的情况,不能寄希望与IE8的普及,这是一件很不靠谱的事情,顽固的IE6用户未必会接受IE8。

所以我们最近一年半载还是不能无视IE6。在设计网页的时候我们也只有花更多时间来用于制作IE6的兼容性。这里我们总结了8个使用有效的HTML和CSS代码来修正网页在IE6下显示错位情况的解决方法。

1. 设置position: relative

将一个元素设置为”position:relative”可以解决很多问题,特别是你曾经遇到隐藏的或对齐诡异的盒子。

2.将浮动元素设置为display:inline

具有margin属性的浮动元素可能引起的IE6双倍margin问题,比如,你为一个元素指定margin-left为5px,但是IE6中实际上却表现为10px。”display:inline”将解决这个问题,当然,方法也不是只有这一个。

3. 将一个元素设置为hasLayout

很多IE6(和IE7)的渲染问题可以通过设置元素的hasLayout来解决。 用来确定相对于其他元素,内容是如何布局和定位的。如果你需要设置一个inline元素(比如一个链接)为block元素,或者是应用透明效果。

最简单的设置hasLayout的方法是为CSS设置一个高度或宽度(zoom也可以用,但是zoom并不是CSS标准的一部分)。我们推荐设置实 际尺寸,但是问题是这是不现实的,你可能需要使用”height:1%”。如果父元素并没有设置高度,该元素的实际高度并不受影响,而且这个时候 hasLayout已经被启用。

4. 修正重复文字bug

复杂的布局可以触发在浮动元素的最后一些字符可能出现在出现在清除元素下面的bug。这里有几个解决方法,有些是完美的,但是做一些反复试验也是必须的:

◆确保所有的元素使用”display:inline;”

◆在最后一个元素上使用一个”margin-right:-3px;”

为浮动元素的最后一个条目使用一个条件注释,比如:

  1. <!–[if !IE]>Put your commentary in here…<![endif]–>
  2.  

在容器的最后元素使用一个空的div(它也有必要设置宽度为90%或类似宽度。)

5. 使用!important 或高级选择器来区分IE6

不使用传统Hack或在额外文件中的条件CSS的方法,写出特别针对IE6的可行的代码也还是有可能的。比如最小高度可以通过这段代码来定义:

  1. #element {  
  2.  min-height: 20em;  
  3.  height: auto !important; /* 所有浏览器都理解这段代码 */  
  4.  height: 20em; /* IE6 错误的使用这个值 /*  

IE6 不理解min-height并错误的用20em覆盖”auto”高度,但是,如果内容需要更多的空间的话,它会自动增加高度。另外一个可选的方法是使用高级选择器,比如e.g。

  1. #element {  
  2. min-height: 20em;  
  3. height: auto !important;  
  4. height: 20em;  
  5. overflow: visible;  

6. 避免百分比单位

百分比会把IE搞糊涂的。除非你可以确切的控制每一个父元素的大小,才可能做到最佳预防。你可以通过!important在其他浏览器中继续使用百分比,比如:

  1. body {  
  2. margin: 2% 0 !important;  
  3. margin: 20px 0; /* IE6 only */  

7. 尽早测试并不断测试

不要等到你的网站或应用完成了才测试IE6;这样的话问题可能更糟糕,而且会花更多时间来修正。如果你的网站能够在Firefox和IE6中正常运行,那么一般在其它浏览器就不会有问题。

8. 重构你的代码

经常发生的事情是,修正bug要比重新考虑一个布局问题要花更长的时间。对HTML做些小改动和一些简单的CSS常常更有效。这可能意味着你要放弃完美的代码,但是会出现较少的长期问题而且将来你会很清楚如果处理这些可能出现的问题。

相信随着IE8浏览器的普及,网站设计的浏览器兼容性问题将会大幅的减少。笔者认为,微软IE8浏览器对于推动网站标准在网站建设中的应用将发挥积极作用。而预测在明年即将问世的IE9,也将会比IE8更好的符合对标准的支持。如果IE浏览器还缺乏对网络标准的支持,那么他也将失去更多的用户。

【编辑推荐】

  1. IE6中常见CSS兼容性解决十大技巧
  2. 解决IE6、IE7、Firefox兼容性最简单方法揭秘
  3. IE6兼容性差功能匮乏 其末日即将来临 
责任编辑:王晓东 来源: IE浏览器
相关推荐

2010-08-18 09:55:38

IE6

2010-09-06 15:06:29

IE6IE7Firefox

2009-08-13 10:12:07

IE的CSS Bug

2010-08-18 15:41:38

IE6E7Firefox

2010-08-27 09:02:22

IE6margin双倍

2009-08-14 09:20:40

抵制IE6

2010-08-18 10:37:16

IE6IE7IE8

2010-09-15 11:08:48

CSSIE6IE7

2010-02-01 08:41:23

GoogleIE6

2010-08-19 14:43:49

IE6IE7IE8

2012-04-06 13:18:58

IE6W3CDIV

2010-08-19 10:40:36

position:fiIE6

2011-11-08 11:07:26

2010-08-18 09:11:11

IE6

2011-05-17 10:33:44

IE6

2010-08-18 09:14:58

IE6兼容性

2010-08-19 09:29:26

hoverIE6

2010-10-08 14:39:43

IE6DIVIE7

2012-03-07 09:44:29

iPadIE6

2010-03-06 08:52:17

点赞
收藏

51CTO技术栈公众号