w3h5

overflow的一些小细节笔记

最近在项目中遇到一个问题,同事在IE浏览器下测试时出现底部大块空白的问题。如下图:

overflow的一些小细节笔记 HTML笔记 第1张

我反复测试,问题并没有重现,最后发现是Windows7系统下的IE浏览器会出现此问题。

经过反复检查,发现在reset文件里面的一行代码的问题,把其中的 overflow-y:scroll; overflow:-moz-scrollbars; 注释掉就好了: 

overflow的一些小细节笔记 HTML笔记 第2张

过程中在思否上找到了一篇 “张鑫旭-overflow的细节笔记”,但是并没有找到张老师的原博客链接,这里就不贴了(如有侵权请告知删除)。

overflow-x 和 overf-y 同时使用的问题

如果 overflow-xoverflow-y 二者的值相同,等同于 overflow  如果二者值不同,其中一个被赋予 visible 另一个被赋予 autohiddenscroll ,其中 visible 会被重置为 auto

table中的问题

tabletd 设置尺寸和 overflow:hidden; 不起作用,此时需要 tabletable-layout:fixed; 才会起作用。

IE7下的button padding问题

overflow的一些小细节笔记 HTML笔记 第3张

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 会缺失。

滚动条导致布局问题

滚动条是会占据宽度的,所以最好是把宽度预留足够。

赞 (0)
分享到: +More |

评论 沙发

换个身份