资讯专栏INFORMATION COLUMN

原生JS获取元素宽高实践详解

stefan / 2440人阅读

摘要:原原获取元素高度这样写之后在的时候发现返回值为。那为什么会是的,百一下谷一下测试一下发现这个这里只能获取的值是标签元素行内样式的值。

开篇的话

任何不是亲身实践中求得的知识,都不是属于你的。

任何求得的知识不去时常温习运用,也不是属于你的。


记录由来

在做个上拉广告功能中遇到了一个“理所当然”觉得对的用法,慢慢才排查出是获取元素高度那里出了问题,这个问题记忆在书上或视频中看到过,许久没用,用的时候就想当然了。遂决定深入剖析用法,增加记忆,记录发表出来,也能给各位前端同行、求学者增加印象。

出错之处

秉承结构、样式、行为分离的宗旨,每次不管大小案例都是分开写html、css、js。这也算抛砖引出了我犯错的玉。

原css:

原js获取DOM元素高度:

var adcon = document.getElementById("adcon");
var maxH = parseInt(adcon.style.height);



这样写之后在console的时候发现:




返回值为NaN。 Orz...

排查错误,找出原因

写个例子测试一下:

仔细查找CSSStyleDeclaration发现height对应值为空

这样就知道为什么会返回NaN了。


那为什么会是""的,百一下谷一下测试一下发现:
这个test.style.xxx 这里只能获取的值是标签元素行内样式的值。
也就是说如果这样写:

CSSStyleDeclaration里才会包括:

这种方式就会取得到值:

扩展需求解决办法,找到各个环境下的最优方法

关于原生JS取dom元素宽高的方法,我总结了以下五种方法,有遗漏的望各位网友提出,谢谢~

window.getComputedStyle(dom元素,"伪类").属性名

dom元素.clientHeight/clientWidth

dom元素.offsetHeight/offsetWidth

dom元素.scrollHeight/scrollWidth

dom元素.style.height/width



光说不练假把式,直接上codes来解释:


getComputedStyle()方法

这个方法是只读的,具体语法和应用的详细讲解可以参见张鑫旭大佬的这篇:传送门

由此可见,这个方法取得值是内容content区域的值,与padding、margin和边框无关。

dom元素.clientHeight/clientWidth方法

可见这是内容区域+上下padding的值。

dom元素.offsetHeight/offsetWidth

可见这是内容区域+两个padding+两个border的值

dom元素.style.height/width

这一开始分析过了,取得是元素行内样式的height值(内容区域的值

dom元素.scrollHeight/scrollWidth

我给例子加了很多内容,出现滚动条:

测试结果:

由此可见,scrollHeight方法返回的还是content内容区域+两个padding的值。

scrollWidth方法返回的是正文内容的总宽度




以上是通过实际测试得出来的结论,个人认为比看一大片干巴巴的文字更容易理解。下一次在实战中遇见应该不会再犯错了。

小白一枚,浅面记录,如有错误、建议、缺漏,恳请指出。

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/53027.html

相关文章

  • 原生JS获取元素宽高实践详解

    摘要:原原获取元素高度这样写之后在的时候发现返回值为。那为什么会是的,百一下谷一下测试一下发现这个这里只能获取的值是标签元素行内样式的值。 开篇的话 任何不是亲身实践中求得的知识,都不是属于你的。任何求得的知识不去时常温习运用,也不是属于你的。 记录由来 在做个上拉广告功能中遇到了一个理所当然觉得对的用法,慢慢才排查出是获取元素高度那里出了问题,这个问题记忆在书上或视频中看到过,许久没用,...

    VishKozus 评论0 收藏0
  • 原生JS获取元素宽高实践详解

    摘要:原原获取元素高度这样写之后在的时候发现返回值为。那为什么会是的,百一下谷一下测试一下发现这个这里只能获取的值是标签元素行内样式的值。 开篇的话 任何不是亲身实践中求得的知识,都不是属于你的。任何求得的知识不去时常温习运用,也不是属于你的。 记录由来 在做个上拉广告功能中遇到了一个理所当然觉得对的用法,慢慢才排查出是获取元素高度那里出了问题,这个问题记忆在书上或视频中看到过,许久没用,...

    Jensen 评论0 收藏0
  • 网页保存为图片及高清截图的优化 | canvas跨域图片配置

    摘要:本次技术调研来源于项目中的一个重要功能需求实现微信长按网页保存为截图。以下主要解决两类跨域的图片资源包括已配置过的中的图片资源和微信用户头像图片资源。 本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。 这里有个栗子(请用微信打开,长按图片即可保存):3分钟探索你的知识边界 将整个网页保存为图片是一个十分有趣的功能,常见于H5活动页的结尾页分享。以下则是项目中...

    zhaochunqi 评论0 收藏0
  • 网页保存为图片及高清截图的优化 | canvas跨域图片配置

    摘要:本次技术调研来源于项目中的一个重要功能需求实现微信长按网页保存为截图。以下主要解决两类跨域的图片资源包括已配置过的中的图片资源和微信用户头像图片资源。 本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。 这里有个栗子(请用微信打开,长按图片即可保存):3分钟探索你的知识边界 将整个网页保存为图片是一个十分有趣的功能,常见于H5活动页的结尾页分享。以下则是项目中...

    GHOST_349178 评论0 收藏0
  • 网页保存为图片及高清截图的优化 | canvas跨域图片配置

    摘要:本次技术调研来源于项目中的一个重要功能需求实现微信长按网页保存为截图。以下主要解决两类跨域的图片资源包括已配置过的中的图片资源和微信用户头像图片资源。 本次技术调研来源于H5项目中的一个重要功能需求:实现微信长按网页保存为截图。 这里有个栗子(请用微信打开,长按图片即可保存):3分钟探索你的知识边界 将整个网页保存为图片是一个十分有趣的功能,常见于H5活动页的结尾页分享。以下则是项目中...

    Galence 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<