今天在开发一个产品列表的时候遇到了一个有趣的问题,关于overflow:auto;在IE6/7下无效的问题,在其他浏览器都是正常的,这个还真是我第一次遇到了这样的问题,不知道其他人有没有遇到过。

我们先来看看我页面的html代码

1
2
3
4
5
<div class="prd_box">
    <ul class="prd_list">
        <li class="list clearfix"></li>
    </ul>
</div>

CSS代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
.prd_box {
  height:610px;
  border:1px solid #ccc;
  background-color:#fff;
  border-top:none;
  overflow:auto;
}
.prd_box .prd_list {
  padding:15px 0 0;
}
.prd_box .prd_list .list {
  width:152px;
  float:left;
  display:inline;
  margin:0 0 0 -1px;
  border-left:1px dashed #E0E0E0;
  padding:12px 12px 15px;
  margin-left:-1px;
  border:none;
  position:relative;
}

以上代码只截取了部分重要的,在现代浏览器里面效果都是正常的,但是在IE6/7下的效果却是这样的


1

当时就看傻了,以为是浏览器问题,然后用虚拟机的真实环境下重看了下效果依旧如此,无言啊。检查了无数次代码,都没什么问题,后面我在
.prd_box层加了position:relative;
后,神奇的IE6/7恢复了正常。无解啊,难道是overflow:auto;
改变了父元素的属性,必须重新给父元素指定position:relative;
才能生效吗?

修改后的CSS:

1
2
3
4
5
6
7
8
.prd_box {
  height:610px;
  border:1px solid #ccc;
  background-color:#fff;
  border-top:none;
  overflow:auto;
  position:relative;
}

修改后IE6/7下效果:

2