详解clientHeight、offsetHeight、scrollHeight、offsetTop、scrollTop

clientHeight:

内容可视区域的高度,也就是说页面浏览器中可以看到内容的这个区域的高度。包括padding但不包括border、水平滚动条、margin的元素的高度。

scrollHeight:

滚动大小,指的是包含滚动内容的元素大小(元素内容的总高度)。

IE、Opera 认为 scrollHeight 是网页内容实际高度,可以小于 clientHeight。
NSFF 认为 scrollHeight 是网页内容高度,不过最小值是 clientHeight。

offsetHeight:

偏移量,包含元素在屏幕上所用的所有可见空间。即包括所有的内边距滚动条和边框大小(padding、border、水平滚动条),不包括外边距margin的高度。

IE、Opera 认为 offsetHeight = clientHeight + 滚动条 + 边框。
NSFF 认为 offsetHeight 是网页内容实际高度,可以小于 clientHeight。

NS、FF 认为 offsetHeight 和 scrollHeight 都是网页内容高度,当网页内容高度小于等于 clientHeight 时,scrollHeight 的值是 clientHeight,而 offsetHeight 可以小于 clientHeight。
IE、Opera 认为 offsetHeight 是可视区域 clientHeight 滚动条加边框。scrollHeight 则是网页内容实际高度。

scrollTop:

代表在有滚动条时,滚动条向下滚动的距离也就是元素顶部被遮住部分的高度。

offsetTop:

当前元素顶部距离最近父元素顶部的距离,和有没有滚动条没有关系。

注意:

offsetHeight = clientHeight + 滚动条 + 边框
同样的属性用document.body和document.documentElement表达出来可能会截然不同。

代码示例:

<script type="text/javascript">
		
		//1.总高度
		height1=document.documentElement.scrollHeight;
		// height1=document.documentElement.offsetHeight;
		//2.文档的高(总高度减去浏览器默认的margin空隙)
		height2=document.body.clientHeight;
		//3.可视区域的高
		height3=document.documentElement.clientHeight;
		//4.已经滚动的高度
		height4=document.documentElement.scrollTop;
		document.write("总高度:"+height1+"<br>");
		document.write("文档的高:"+height2+"<br>");
		document.write("可视区域的高:"+height3+"<br>");
		document.write("已经滚动上去的高:"+height4);
		//测试已经滚动上去的高度,动态显示在网页标题中
		window.onscroll=function(){
			h=document.documentElement.scrollTop;
			document.title=h;
		}
	</script>

浏览器实现效果:

在这里插入图片描述

在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

若年封尘

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值