scrollheight
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.scrollHeight
与document.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取得。
相关阅读
【带图】讲解offsetHeight、offsetLeft、clientWidth
1.偏移量元素的可见大小由其高度、宽度决定,包括所有内边距、滚动条和边框的大小(注意,不包括外边距)。offsetHeight:元素在垂直方向上
搞清clientHeight、offsetHeight、scrollHeight、offs
转载自:https://www.imooc.com/article/17571网页可见区域高:document.body.clientHeight网页正文全文高:document.body.scrollHeigh
彻底分清clientHeight,scrollHeight,offsetHeight,client
clientHeight,scrollHeight,offsetHeight clientHeight: 可理解为内部可视区高度,样式的height+上下padding scrollHeight:
JS中offsetTop、clientTop、scrollTop、offsetTop各位
这里是javascript中制作滚动代码的常用属性页可见区域宽: document.body.clientWidth;网页可见区域高: document.body.clientHeight