日期:2014-05-17  浏览次数:20779 次

ie6,ie7,ie8 css bug兼容解决记录

转载自:http://www.wufangbo.com/ie6-ie7-ie8-css-bug-2

?

断断续续的在开发过程中收集了好多的bug 以及其解决的办法,都在这个文章里面记录下来了!希望以后解决类似问题的时候能够快速解决

,也希望大家能在留言里面跟进自己发现的ie6 7 8bug 和解决办法!

1:li边距“无故”增加

任何事情都是有原因的,li边距也不例外。

先描述一下具体状况:有些时候li边距会突然增加很多,值也不固定(只在IE6/IE7有这种现象),让人摸不着头脑,仔细“研究”发现是由于其低级元素ul的padding引起,padding的上下值对li有影响,左右无影响。所以只好笨手笨脚地把padding去掉,换成margin。这是能解决问题,但往往不是我们想要的结果,或许还会引起其他不必要的怪现象。

现在终于发现解决这个问题的方法,其实很简单,既然是有ul引起的,就设置ul的显示形式为*display:inline-block;即可,前面加*是只针对IE6/IE7有效,其他浏览器并不渲染这个属性。

2:分页数字字体用“Arial”加粗不抖动

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDXHTML1.0Transitional//EN""http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<htmlxmlns="http://www.w3.org/1999/xhtml">
<head>
<metahttp-equiv="Content-Type"content="text/html;charset=gb2312"/>
<title>无标题文档</title>
<linkhref="css/style.css"rel="stylesheet"type="text/css"/>
<styletype="text/css">
body,ul,h1{
font-family:Arial;
font-size:12px;
}
.page{
text-align:center;
}
.pagea{
display:inline-block;
padding:5px8px;
text-decoration:none;
border:1pxsolid#09F;
background-color:#0CF;
color:#FFF;
}
.pagea:hover,.page.selected{
border:1pxsolid#CCC;
background-color:#FFF;
color:#000;
font-weight:bold;
}
</style>
</head>
<body>
<h1>分页样式</h1>
<divclass="page"><ahref="#">1</a><ahref="#"class="selected">2</a><ahref="#">3</a><ahref="#">4</a><ahref="#">5</a>
<ahref="#">6</a><ahref="#">7</a><ahref="#">8</a><ahref="#">9</a><ahref="#">10</a></div>

</body>
</html>

3:IE6CSS选择器区分IE6
IE6不支持子选择器;先针对IE6使用常规申明CSS选择器,然后再用子选择器针对IE7+及其他浏览器。
/*IE6专用*/
.content{color:red;}
/*其他浏览器*/
div>p.content{color:blue;}

4:IE6最小高度
IE6不支持min-height属性,但它却认为height就是最小高度。解决方法:
使用ie6不支持但其余浏览器支持的属性!important。
#container{min-height:200px;height:auto!important;height:200px;}

5:IE6100%高度
在IE6下,如果要给元素定义100%高度,必须要明确定义它的父级元素的高度,如果你需要给元素定义满屏的高度,就得
先给html和body定义height:100%;。

6:IE6躲猫猫 bug
在IE6和IE7下,躲猫猫bug是一个非常恼人的问题。一个撑破了容器的浮动元素,如果在他之后有不浮动的内容,并且有一
些定义了:hover的链接,当鼠标移到那些链接上时,在IE6下就会触发躲猫猫。
解决方法很简单:
1.在(那个未浮动的)内容之后添加一个<spanstyle="clear:both;"></span>
2.触发包含了这些链接的容器的hasLayout,一个简单的方法就是给其定义height:1%;

7:IE6绝对定位 元素的1像素间距bug
IE6下的这个错误是由于进位处理误差造成(IE7已修复),当绝对定位元素的父元素高或宽为奇数时,bottom和right会
产生错误。唯一的解决办法就是给父元素定义明确的高宽值,但对于液态布局没有完美的解决方法。

8:IE下z-index 的bug
在IE浏览器中,定位元素的z-index 层级是相对于各自的父级容器,所以会导致z-index出现错误的表现。解决方法是给
其父级元素定义z-index,有些情况下还需要定义position:relative。

9:OverflowBug
在IE6/7中,overflow无法正确的隐藏有相对定位position:relative;的子元素。解决方法就是给外包容器.wrap加上
position:relative;。

10:横向列表宽度bug
如果你使用float:left;把<li>横向摆列,并且<li&