今天在开发一个产品列表的时候遇到了一个有趣的问题,关于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下的效果却是这样的

当时就看傻了,以为是浏览器问题,然后用虚拟机的真实环境下重看了下效果依旧如此,无言啊。检查了无数次代码,都没什么问题,后面我在
.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下效果:
