关于scrollHeight和scrollTop取值为0的问题

本文探讨了在JavaScript中遇到scrollHeight和scrollTop取值为0的问题,详细解析了offsetTop、offsetLeft等属性,并指出Firefox下scrollHeight的特殊行为。同时,提到了浏览器兼容性问题,尤其是Chrome不识别&符号。解决方案包括考虑多种获取方法来确保网页内容高度和滚动位置的正确获取。

js:关于scrollHeight和scrollTop取值为0的问题

  • obj.offsetTop 指 obj 距离上方或上层控件的位置,整型,单位像素。
  • obj.offsetLeft 指 obj 距离左方或上层控件的位置,整型,单位像素。
  • obj.offsetWidth 指 obj 控件自身的宽度,整型,单位像素。
  • obj.offsetHeight 指 obj 控件自身的高度,整型,单位像素。(clientHeight + 滚动条 + 边框)
  • obj.scrollHeight网页内容的高度,最小值是clientHeight。

offsetTop与style.top的区别

  • offsetTop 返回的是数字,而 style.top 返回的是字符串,除了数字外还带有单位:px。
  • offsetTop 只读, style.top 可读写。
  • 如果没有给 HTML 元素指定过 top 样式,则 style.top 返回的是undefined。(也就是说内联样式与外联样式和内嵌样式都没有设置style.xx则js是无法设置该元素相应的的style.xx)

问题及解决

所以document.body.scrollHeightdocument.documentElement.scrollHeight都是获取网页页面内容的高。

但是今天我发现使用他们时并没有达到我想要的效果,仔细查看发现firefox下document.body.scrollHeight的值始终是0,下面是测试:

 

height&top


firefox下:

 

 

firefox


Chrome下

 

 

chrome


IE11下

 

 

IE11


可以发现chrome对document.documentElement.scrollHeight&document.documentElement.scrollTop是不能识别的,而firefox和IE11不能识别document.body.scrollHeight&document.body.scrollTop,所以要考虑的网页的兼容性,建议两种获取方法都要写在代码里。

 

另外我也测试clientXxx,写在总结里吧。

总结

在js中需要取scrollHeight值和scrollTop值时,我们需要使用:

var oHeight=document.body.scrollHeight==0?document.documentElement.scrollHeight:document.body.scrollHeight;

var oTop=document.body.scrollTop==0?document.documentElement.scrollTop:document.body.scrollTop;

关于scrollWidth:
var oWidth=document.body.scrollWidth;&var oWidth=document.documentElement.scrollWidth;都不会出现兼容问题

取clientXxx值只能:var wWidth=document.documentElement.clientXxx;
粗略测试当前只需要对scrollTop作为零判断,scrollHeight / clientXxx都可以通过document和body取得。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值