判断是否有滚动条的方法
其实只需要一行 JS 就可以,测试兼容 IE7
一般情况下,使用 document.body.scrollHeight > window.innerHeight
就可以判断。
但是在 IE7,IE8 中 window.innerHeight
为 underfined
,所以为了兼容 IE7、IE8,需要使用 document.documentElement.clientHeight
属性计算窗口高度。
计算滚动条宽度的方法
还是以弹窗为例,因为 IE 10 以上以及移动端浏览器的滚动条都是不占据页面宽度的透明样式(其中 IE 10 以上浏览器可以通过 CSS 属性还原原始的滚动条样式),所以为了进一步增强用户体验,我们还需要计算滚动条的宽度,根据情况添加合理的 margin-left
数值。
计算滚动条宽度的方法比较简单,新建一个带有滚动条的 div
元素,通过该元素的 offsetWidth
和 clientWidth
的差值即可获得,我在此借鉴 Magnific-popup 中的方法