overflow的一些小细节笔记

最近在项目中遇到一个问题,同事在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 会缺失。

滚动条导致布局问题

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

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

扫码关注云+社区

领取腾讯云代金券