js中不同的height, top的区别对比
每次看到js中的 clientheight(clienttop), offsetheight(offsettop),scrollheight(scrolltop)就头大,根本分不清这几种的区别,然而碰到这些已经不 值一两次了,然后每次都要查看一下各自的区别,才能决定使用哪个。
本篇主要以chrome为准,可能各个浏览器之间还是有一些区别,但很多自己还未真正遇到过,还不是很清楚,等以后碰到了类似的兼容性问题,再记录到这里,这次就chrome浏览器中各个属性的区别做个记录,以方便以后的查看
一 clientheight,offsetheight,scrollheight的区别
clientheight在各个浏览器中基本是一样的,一致认为是内容可视区域的高度,也就是说页面浏览器中可以看到内容的这个区域的高度,不包括滚动条,不包括margin,但包括padding,也就是说实际的clientheight = 当前对象可视区域的高度 + padding值,如下图所示 clientheight = 对象可视区域高度(300) + 上下padding值(20) = 320
在不同浏览器都实用的javascript方案:
var w= document.documentelement.clientwidth || document.body.clientwidth; var h= document.documentelement.clientheight || document.body.clientheight;
offsetheight = 当前对象的高度 + 滚动条 + borde值 + padding值,上图中当前对象的高度和可视区域高度是一样的,所以offsetheight = 300 + padding(20px ) + border(10px) = 330
scrollheight是网页内容的实际高度,最小值就是clientheight,也就是说可以是跟clientheight相等的,但我们假设这样一个情形,如下代码所示,父div高度是300px,子div高度是500px,这时候就会形成滚动条,此时父div的结构图如下:
父div的的scrollheight 就应该是scrollheight = 500px + padding值
因为此时产生了滚动条,此时父div的可视区域高度为283,当前对象高度也就是父div的高度为300,因此
clientheight = 283px + padding值(20px) = 303px
offsetheight = 父div的高度(300px) + padding值(20px) + 边框(10px) = 330px
<div id="parent" style="padding:10px;border:5px red solid;height:300px;width:200px;overflow:auto"> <div style="height:500px;width:400px"></div> </div>
二 clienttop,offsettop,scrolltop的区别
clienttop的理解可以参考clientheight,clientheight的的计算方式是当前可视区域的高度 加上 padding值,那么clienttop就可以理解为当前可视区域到上一级元素的距离。
如上图所示,clienttop就是5px,大部分情况下,clienttop都是这个border值。
offsettop是当前对象到body元素的距离,它的计算方式相对复杂,先从上图进行理解,当前对象指的是border边框之内的区域,所以计算offsettop要从当前对象的margin开始,计算公式如下 offsettop = 当前对象的margin-top + 当前对象所有上级元素的margin-top + 当前对象所有上级元素的border-top,需要注意的是offsettop是不能进行直接赋值的,只能通过这样的计算方式得到。
scrolltop是当前对象的最顶部到当前对象在当前窗口显示的范围内的顶边的距离.即是在出现了纵向滚动条的情况下,滚动条拉动的距离。
以上就是js中不同的height、 top的区别对比,希望对大家的学习有所帮助。
上一篇: 女产品经理一眼心动 小米CC9真机官图公布:白色梦幻
下一篇: 钱比生命重要!
推荐阅读
-
Node.js 中exports 和 module.exports 的区别
-
微信小程序 image组件binderror使用例子与js中的onerror区别
-
js获取元素坐标位置(js中var和let的区别)
-
js中innerText/textContent和innerHTML与target和currentTarget的区别
-
JS中创建函数的三种方式及区别
-
微信小程序 image组件binderror使用例子与js中的onerror区别
-
JS中的forEach、$.each、map方法对比讲解
-
js中null与空字符串""的区别讲解
-
JS中的位置和宽度:clientWidth、offsetWidth、scrollWidth等区别介绍
-
详解JS取出两个数组中的不同或相同元素