解决vue项目获取dom元素宽高总是不准确问题
dom元素内部内容是动态的,重置数据后直接获取宽高总是不准确:
this.$refs.editor[0].offsetHeight;
原因:重置数据后获取dom元素宽高时,dom元素还未渲染完毕;
解决方法:利用Vue.nectTick(callback)
this.$nextTick(() => { this.$refs.editor[0].offsetHeight;})
Vue.nectTick() 是在下次DOM更新循环结束之后执行延迟回调
补充知识:vue 获取 指定元素的高度宽度等(使用vue中的 ref 获取到的是 dom 元素高度或者宽度)
使用 vue 的时候,想要获得一个指定的元素的高度时,可以使用 vue 中的 ref 。
当 ref 加在普通的元素上,使用 this.ref.name 获取到的是 dom 元素
示例
写在 页面 html 部分的
<div ref='init'></div>
写在 页面 方法 部分
这里的 offsetHeight 是返回元素的宽度(包括元素宽度、内边距和边框,不包括外边距)
let height= this.$refs.init.$el.offsetHeight;
这里的offsetHeight可以替换,用来获取其他的属性
offsetWidth //返回元素的宽度(包括元素宽度、内边距和边框,不包括外边距)
offsetHeight //返回元素的高度(包括元素高度、内边距和边框,不包括外边距)
clientWidth //返回元素的宽度(包括元素宽度、内边距,不包括边框和外边距)
clientHeight //返回元素的高度(包括元素高度、内边距,不包括边框和外边距)
style.width //返回元素的宽度(包括元素宽度,不包括内边距、边框和外边距)
style.height //返回元素的高度(包括元素高度,不包括内边距、边框和外边距)
scrollWidth //返回元素的宽度(包括元素宽度、内边距和溢出尺寸,不包括边框和外边距),无溢出的情况,与clientWidth相同
scrollHeigh //返回元素的高度(包括元素高度、内边距和溢出尺寸,不包括边框和外边距),无溢出的情况,与clientHeight相同
除此之外,还可以获取带有单位的数值
let height = window.getComputedStyle(this.$refs.init).height;
这样获取的值是有单位的。
以上这篇解决vue项目获取dom元素宽高总是不准确问题就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持好吧啦网。
相关文章:
1. 《CSS3实战》笔记--渐变设计(一)2. XML在语音合成中的应用3. 用css截取字符的几种方法详解(css排版隐藏溢出文本)4. CSS Hack大全-教你如何区分出IE6-IE10、FireFox、Chrome、Opera5. chatGPT教我写compose函数的详细过程6. Vue Element UI 表单自定义校验规则及使用7. 在 XSL/XSLT 中实现随机排序8. JavaScript避免嵌套代码浅析9. asp(vbs)Rs.Open和Conn.Execute的详解和区别及&H0001的说明10. CSS3实例分享之多重背景的实现(Multiple backgrounds)
