ie7中overflow:auto无效的解决方法

(编辑:jimmy 日期: 2024/10/31 浏览:2)

产生原因
当父元素的直接子元素或者下级子元素的样式拥有position:relative属性时,父元素的overflow:auto属性就会失效。

解决办法
解决这个bug很简单,在父元素中使用position:relative;即可解决该bug。

代码bug重现

复制代码代码如下:
<ul>
<li>我是很努力的前端博客,希望你会喜欢</li>
<li>我是很努力的前端博客,希望你会喜欢</li>
<li>我是很努力的前端博客,希望你会喜欢</li>
<li>我是很努力的前端博客,希望你会喜欢</li>
<li>我是很努力的前端博客,希望你会喜欢</li>
</ul>


复制代码代码如下:
ul{overflow:auto; height:100px;}
li{position:relative; height:30px; line-height:30px;}

在ie7中是会出现奇怪bug,有滚动条出现,但是无法拉动滚动条。解决就是给ul{position:relative;}

IE7 float:right会换行
以前以为是ie6才会出现,没想到ie7也同样有这个bug,网上很多说把float:right的元素放在最前面,这是有多么2的想法啊。牺牲一个元素的位置来解决这个bug,有时候你自己看代码时都有点无语,解决方法可以给父层加一个相对定位,然后给这个右边加一个绝对定位来实现。我觉得这样子比较靠谱点。

以上就是这篇文章的全部内容,希望对大家的学习和工作能有一定的帮助。

一句话新闻

高通与谷歌联手!首款骁龙PC优化Chrome浏览器发布
高通和谷歌日前宣布,推出首次面向搭载骁龙的Windows PC的优化版Chrome浏览器。
在对骁龙X Elite参考设计的初步测试中,全新的Chrome浏览器在Speedometer 2.1基准测试中实现了显著的性能提升。
预计在2024年年中之前,搭载骁龙X Elite计算平台的PC将面世。该浏览器的提前问世,有助于骁龙PC问世就获得满血表现。
谷歌高级副总裁Hiroshi Lockheimer表示,此次与高通的合作将有助于确保Chrome用户在当前ARM兼容的PC上获得最佳的浏览体验。