+
80
-

js怎么获取当前元素在屏幕上显示的位置与尺寸?

js怎么获取当前元素在屏幕上显示的位置与尺寸?

使用csstree和dom tree还有layout tree获取不是很精确,有没有其他的办法?

const rect = dom.getBoundingClientRect():

getComputedStyle(dom).width


网友回复

+
0
-

四种方式可以获取dom元素的长度位置

dom.getBoundingClientRect().width:

获取方式: 使用 getBoundingClientRect 方法获取包含元素在视口中位置和尺寸的 DOMRect 对象,然后获取它的 width 属性。

注意事项: 返回的宽度值是一个浮点数,表示元素在视口中的宽度,包括边框。

还有top、right、height、bottom、right等属性值。

getComputedStyle(dom).width:获取方式: 使用 getComputedStyle 方法获取元素的计算后样式,然后获取它的 width 属性。类似于f12开发者工具中看到的计算后的css属性。

注意事项: 返回的宽度值是一个字符串,包含单位,表示元素的计算后宽度,包括边框、内边距等。

dom.clientWidth:

获取方式: 获取元素的客户区宽度,即内容区宽度加上内边距。

注意事项: 不包括边框和外边距。

dom.offsetWidth 和 dom.scrollWidth:

dom.offsetWidth: 获取元素的整体宽度,包括内容区、内边距和边框,但不包括外边距。

dom.scrollWidth: 获取元素的内容区域的总宽度,包括内容区宽度和溢出部分的宽度。

注意事项: 返回的宽度值是一个整数。

dom.style.width:获取方式: 直接访问元素的 style 属性获取内联样式中的宽度。

注意事项: 只能获取或设置内联样式中的宽度,不包括外部样式表或嵌套样式表中的样式。

通常情况下,getBoundingClientRect().width 和 getComputedStyle(dom).width 更适合获取计算后的宽度,而 dom.clientWidth、dom.offsetWidth 和 dom.scrollWidth 更适合获取元素的宽度属性。dom.style.width 则主要用于操作内联样式。

我知道答案,我要回答