最近在项目中遇到一个问题,同事在IE浏览器下测试时出现底部大块空白的问题。如下图:
我反复测试,问题并没有重现,最后发现是Windows7系统下的IE浏览器会出现此问题。
经过反复检查,发现在reset文件里面的一行代码的问题,把其中的 overflow-y:scroll; overflow:-moz-scrollbars; 注释掉就好了:
过程中在思否上找到了一篇 “张鑫旭-overflow的细节笔记”,但是并没有找到张老师的原博客链接,这里就不贴了(如有侵权请告知删除)。
overflow-x 和 overf-y 同时使用的问题
如果 overflow-x 和 overflow-y 二者的值相同,等同于 overflow 如果二者值不同,其中一个被赋予 visible 另一个被赋予 auto , hidden , scroll ,其中 visible 会被重置为 auto 。
table中的问题
table 中 td 设置尺寸和 overflow:hidden; 不起作用,此时需要 table 为 table-layout:fixed; 才会起作用。
IE7下的button padding问题
overflow: scroll 的出现
所有的 scroll 均是来自于 html ,不是 body 。证明就是 body 本身是有 .5em 的的 margin 。可是滚动条确实贴着 html 的。
ie7及以下
默认右侧始终有一个 scroll 的条。即使你的内容一个字没写。所以他的默认css的 overflow-y:scroll;
IE8+
默认是 overflow:auto;
chrome和其他浏览器
在这里,奇葩的是chrome了。
chrome下获取滚动高度是 document.body.scrollTop
而其他的是 document.documentElement.scrollTop
所以推荐的兼容写法是:
var scrollTop = Math.max(document.body.scrollTop, document.documentElement.scrollTop);
padding-bottom缺失
在非chrome浏览器中。如果滚动区域写了上下 padding ,那么 padding-bottom 会缺失。
滚动条导致布局问题
滚动条是会占据宽度的,所以最好是把宽度预留足够。
未经允许不得转载:前端资源网 - w3h5 » overflow的一些小细节笔记