scrollTop、clientHeight、 scrollHeight...学完真的理解了

这篇具有很好参考价值的文章主要介绍了scrollTop、clientHeight、 scrollHeight...学完真的理解了。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

在开发中我们常常会用到判断滚动条是否触底的逻辑。我一般都会在网上搜一段代码,这段代码有用到scrollTop、clientHeight、 scrollHeight 。接着我简单看一下好像理解了,再在项目里用一下好使了就没去深入研究相关概念。等下次用到了还是搜一下,自己写不出来…于是笔者想想深入研究一下这些概念好摆脱尴尬的局面。

看了很多的文章,感觉有一些写的不够详细具体,要么就是概念的堆砌没有例子和图,要么就是一张图写满了各种概念不易于理解。于是笔者自己对照MDN文档总结了一下这些概念,并结合示例加深对这些概念的理解,并总结了这些概念彼此之间的数量关系和应用场景。欢迎大家阅读,有写错或者理解错的地方请不吝指正。

1.clientWidth、clientHeight、clientLeft、clientTop

1.1 clientWidth

(1)含义:只读属性,表示元素的内部宽度,单位为像素。

(2)从盒子模型角度看:包含padding,但不包含border, margin 以及垂直滚动条。

(3)注意:内联元素clientWidth为0。

(4)语法:element.clientWidth;

clientheight,html,前端,css

1.2 clientHeight

(1)含义:只读属性,表示元素的内部高度,单位为像素。

(2)从盒子模型角度看:包含padding,但不包含border, margin 以及水平滚动条。

(3)注意:内联元素clientHeight为0。

(4)语法:element.clientHeight;

1.3 clientLeft

(1)含义:只读属性,表示一个元素左边框的宽度,单位为像素。

(2)从盒子模型角度看:clientLeft 不包括左外边距和左内边距.

(3)语法:element.clientLeft

(4)备注:如果元素的文本方向是从右向左(RTL, right-to-left),并且由于内容溢出导致左边出现了一个垂直滚动条,则该属性包括滚动条的宽度。

1.4 clientTop

(1)含义:只读属性,表示一个元素顶部边框的宽度,单位为像素。

(2)从盒子模型角度看:不包括顶部外边距或内边距

(3)语法:element.clientTop

1.5 示例演示

以如下的盒子模型来验证来看一下这些值以及计算过程(采用的例子是MDN上的,您可以打开控制台自己试一下):

(1)首先控制台获取Dom元素:
const div = document.getElementById('iddiv') 
(2)然后在 Eelments->Computed 看盒模型:
clientheight,html,前端,css
(3)查看clientWidth的值:
clientheight,html,前端,css

clientWidth计算:内容宽度+左右padding即 182+28*2 = 182 + 56 = 238

(4)查看clientHeight的值:
clientheight,html,前端,css

clietentHeight计算:内容高度+上下padding即 102 + 0 = 102

(5)查看clientLeft和clientTop值:
clientheight,html,前端,css

clientLeft和clientTop计算:左边框 24 ; 上边框24

注意以上的计算过程是笔者在盒模型的设置为:box-sizing: content-box时的计算方法,如果盒模型设置为 box-sizing: border-box; 则计算clientWidth 和 clientHeight的方法为:

(1)clientWidth :clientWidth 可以通过 CSS width+ CSS padding - 垂直滚动条宽度 (如果存在) 来计算

(2)clientHeight:clientHeight 可以通过 CSS height + CSS padding - 水平滚动条高度 (如果存在) 来计算

以clientWidth的计算为例说明一下

clientheight,html,前端,cssclientheight,html,前端,css

首先按照正常算法计算: 95 + 28*2 = 95 + 56 = 151 。151大于134 , 时因为还没有扣除滚动条的宽度,滚动条的宽度 为 151- 134 = 17 , 量了一下滚动条的宽度确实为17,如下图所示:

clientheight,html,前端,css

2.offsetWidth、offsetHeight、offsetLeft、offsetTop

2.1 offsetWidth

(1)含义:只读属性,返回元素的布局宽度,单位像素。

(2)从盒子模型角度看:包含通过css设置的width,border, padding以及竖直方向滚动条的宽度。

(3)语法:element.offsetWidth

(4)备注:各浏览器的 offsetWidth 可能有所不同。

2.2 offsetHeight

(1)含义:只读属性,元素的布局高度,单位像素。

(2)从盒子模型角度看:包含通过css设置的height, border, padding以及水平方向滚动条的高度。

(3)语法:element.offsetHeight

(4)备注:如果元素被隐藏则返回0。

接下来要介绍offsetLeft和offsetTop的含义,在这之前要明白offsetParent的含义:

HTMLElement.offsetParent 是一个只读属性。
返回一个指向最近的(指包含层级上的最近)包含该元素的定位元素或者最近的 table,td,th,body元素。
当元素的 style.display 设置为 "none" 时,offsetParent 返回 null 

2.3 offsetLeft

(1)含义:只读属性,当前元素左上角相对于offsetParent左边界的偏移。

(3)语法:element.offsetLeft

(4)备注:如果元素被隐藏则返回0。

2.4 offsetTop

(1)含义:只读属性,当亲元素相对于offsetParent元素的顶部内边距的距离。

(3)语法:element.offsetTop

(4)备注:如果元素被隐藏则返回0。

2.5 示例演示

笔者写了一个demo用来说明如上概念,代码如下:

<html lang="en"><head><style> .parent {width: 400px;height: 400px;border: 1px solid #ccc;padding-top: 50px;padding-left: 20px;}.child {width: 200px;height: 200px;padding: 10px;border: 10px solid black;overflow: auto;} </style></head><body><div class="parent"><div class="child" id="child-id"><!-- 省略内部内容 --></div></div></body>
</html> 

代码运行效果以及盒子模型如下图所示:

(1)获取内部div Dom元素
const div = document.getElementById('child-id') 
(2)查看offsetWidth的值
clientheight,html,前端,css

其计算过程:border 20 + pading 20 + content 183 + 滚动条 17 = 240。也就是: 20 + 20 + 200= 240

如果设置 box-sizing:border-box 则对应的盒子模型变为:

clientheight,html,前端,css

此时查看offsetWidth的值:

clientheight,html,前端,css

其计算过程: content 160 + padding 20 + border 20 = 200 。我们观察实际效果:

发现虽然computed的盒子模型显示padding是10 ,但实际上并不是10了,而且由于滚动条的存在左右显示的padding所占空间已经不相等。

(3)读取offsetHeight值

计算过程与offsetWidth类似: 183 content + 17 滚动条 +20 padding + 20 border = 240。如果设置 box-sizing:border-box 则offsetHeight值如下:

clientheight,html,前端,css
(4)读取offsetTop和offsetLeft的值
clientheight,html,前端,css

如上我们发现offsetParent为body元素, 那么offsetTop值为59 , offsetLeft的值为29,都是怎么算出来的啊?看一下body以及class为parent的外层div的盒模型结构:

clientheight,html,前端,cssclientheight,html,前端,css

参考盒子模型结构我们可以得到计算过程:

offsetTop : 8 (body padding) + 1 (parent border) +50 (parent padding) = 59

offsetLeft: 8 (body padding) + 1 (parent border) + 20 (parent padding) = 29

3.scrollLeft、scrollTop、scrollWidth、scrollHeight

3.1 scrollLeft

(1)含义:可读取可设置,一个元素的内容水平滚动的像素数(滚动条到元素左边的距离)。

(2)语法:Element.scrollLeft

(3)备注:注意如果这个元素的内容排列方向是rtl (right-to-left) ,那么滚动条会位于最右侧(内容开始处),并且scrollLeft值为 0。此时,当你从右到左拖动滚动条时,scrollLeft 会从 0 变为负数。

3.2 scrollTop

(1)含义:可读取可设置,一个元素的内容垂直滚动的像素数。

(2)语法:Element.scrollTop

(3)备注:一个元素的 scrollTop 值是这个元素的内容顶部(卷起来的)到它的视口可见内容(的顶部)的距离的度量。注意,这里并没有描述为滚动条距离顶部的距离,当然这样理解也没问题。当一个元素的内容没有产生垂直方向的滚动条,那么它的 scrollTop 值为0。

3.3 scrollWidth

(1)含义:只读属性,是一个元素内容宽度的度量,包括由于溢出导致的视图不可见内容。

(2)语法:Element.scrollWidth

(3)备注:没有水平滚动条的情况下,scrollWidth 值与元素视图填充所有内容所需要的最小值clientWidth相同。

3.4 scrollHeight

(1)含义:只读属性,是一个元素内容高度的度量,包括由于溢出导致的视图不可见内容。

(2)语法:element.scrollHeight

(3)备注:没有垂直滚动条的情况下,scrollHeight 值与元素视图填充所有内容所需要的最小值clientHeight相同。

为了说明scrollHeight 的含义,MDN文档给出了如下的示意图:

clientheight,html,前端,css

3.5 示例演示

示例代码任然沿用2.5 节的demo示代码, 运行效果如下:

(1)查看scrollLeft的值

如上图所示:水平方向上滚动条没有向右滚动时,则scrollLeft的值为0。

如上图所示:水平方向滚动条向右滚动了一定距离,则此时scrollLeft的值为58。

(2)查看scrollTop的值

如上图所示:竖直方向上滚动条没有向下滚动时,则scrollTop的值为0。

如上图所示:竖直方向上滚动条没有向下滚动了一定距离,则此时scrollTop的值为59。

(3)查看crollWidth的值

如上图所示:scrollWidth的值为704,代表内容的宽度。

(4)查看scrollHeight的值

如上图所示:scrollHeight的值为262,代表内容的高度。

4.彼此之间的数量关系以及应用

(1)关系1

没有竖直方向上的滚动条: scrollHeight = clientHeight

应用:判断竖直方向是是否有滚动条

(2)关系2

没有水平方向上的滚动条:scrollWidth = clientWidth

应用:判断水平方向是否有滚动条

(3)关系3

scrollTop + clientHeight >= scrollHeight

因为scrollTop是一个非整数,而scrollHeight和clientHeight是四舍五入的,因此确定滚动区域是否滚动到底的唯一方法是查看滚动量是否足够接近某个阈值:

Math.abs(element.scrollHeight - element.clientHeight - element.scrollTop) < 1 

5.总结

一图胜千言,本文的全部内容如下:文章来源地址https://www.toymoban.com/news/detail-804819.html

clientheight,html,前端,css

到了这里,关于scrollTop、clientHeight、 scrollHeight...学完真的理解了的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 如何理解《注意力机制真的懂得“集中注意力”吗?》

    在文章《从熵不变性看Attention的Scale操作》中,我们就从“集中注意力”的角度考察过Attention机制,当时我们以信息熵作为“集中程度”的度量,熵越低,表明Attention越有可能集中在某个token上。 但是,对于一般的Attention机制来说,Attention矩阵可能是非归一化的,比如《FLAS

    2024年02月05日
    浏览(39)
  • 你真的理解qsort函数吗?带你深度剖析qsort函数

    魔王的介绍:😶‍🌫️一名双非本科大一小白。 魔王的目标:🤯努力赶上周围卷王的脚步。 魔王的主页:🔥大魔王不哭 我们初识C语言时,会做过让一个整型数组按照从小到大来排序的问题,我们使用的是冒泡排序法,但是如果我们想要比较其他类型怎么办呢,显然我们

    2023年04月24日
    浏览(40)
  • C真的不难学,不信就看下我关于循环的理解

    人生就是日复一日地不断的重复,既有相同的事情,也有相似的事情,却无论如何也无法回到最初。要想在生活的每一时刻都能有新的发现,恐怕只是一个美好的愿望。 下面将会给大家介绍程序中的重复流程——循环。 C语言中提供了3中循环执行语句,首先我们来看下do循环

    2024年02月08日
    浏览(75)
  • 「数据库、数据库连接池、数据源」这些概念你真的理解了吗?

    我学习的过程中,对于连接池和数据源分得不是很清楚,而且我发现有的人将数据库等同于数据源,或者将数据源等同于连接池,实际上这些说法并不准确。 在某次工作中,同事 A 说道,这个数据源不行,那么换一个数据源就可以了,结果我看他操作,原来是改写了配置中的

    2023年04月21日
    浏览(62)
  • JavaScript中的scrollTop(js中的scrollTop,滚动到顶部,javascript滚动到顶部)

    简述:scrollTop是JavaScript中一个非常有用且重要的方法,它用于获取或设置元素的垂直滚动条位置,实现各种滚动相关的功能,无论是回到顶部、滚动到指定位置还是监听滚动事件,都需要用到scrollTop,在本文中,我们将深入了解scrollTop的用法和实际应用,这是一张scrollTop的关

    2024年02月08日
    浏览(46)
  • window.scrollTop 不生效的原因,如何解决

    当我想要在移动端项目中设置返回顶部按钮时,需要用到window.scrollTo()这个函数,但是我在设置点击事件后返回顶部不生效。 经过查阅资料才发现,这个方法,是只给产生滚动条的元素进行返回,而不是window,我这里是给index元素设置了滚动条。 后续就是获取到当前滚动条的

    2024年02月12日
    浏览(25)
  • offsetTop、clientTop、scrollTop等属性详解【概念+详细例子分析】

    MDN中offset… offsetWidth/offsetHeight :对象的可见宽度 offsetLeft/offsetTop: 当前元素距浏览器边界的偏移量,以像素为单位。 1、 offsetTop、offsetLeft offsetTop:元素到offsetParent顶部的距离(当前元素顶部距离最近父元素顶部的距离) offsetParent:距离元素最近的一个具有定位的祖宗元素(

    2024年02月11日
    浏览(31)
  • vue页面设置滚动失败的解决方案(scrollTop一直为0)

    背景 希望页面能跳转到 某一位置用到了scrollTop属性。可是发现给某个div设置该属性后,一致为0。找了很多方案,但不都适合自己,或者说不知道是否适合。 怎么看我这个方法适不适合你 你可以尝试打印滚动条的位置,页面滚动后,再次打印滚动条的位置,如果一直为0的话,那我

    2024年02月04日
    浏览(69)
  • 使用scrollTo/scrollTop让页面元素滚动到指定位置, 并设置滚动动画

    当容器有滚动条时,有时需要点击 试图 或 节点 将页面滚动到指定元素位置 比如父元素设置了 overflow: hidden; ,当元素里的内容超过元素本身的高度时, 就会出现滚动条, 那么鼠标滑动的距离就是其滚动距离. scrollTop属性 scrollTop 就是指 “元素中的内容” 超出 “元素上边界” 的

    2023年04月27日
    浏览(76)
  • scrollTop与offsetTop解决小分辨率区域块向上滚动效果效果,结合animation与@keyframes实现标题左右闪动更换颜色效果。

    scrollTop 是一个属性,它表示元素的滚动内容垂直滚动条的位置。对于可滚动元素, scrollTop 属性返回垂直滚动条滚动的像素数,即元素顶部被隐藏的像素数。  offsetTop 是一个属性,用于获取一个元素相对于其父元素的垂直偏移量(距离)。具体来说,返回的是一个元素的顶部

    2024年02月02日
    浏览(46)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包