解决vue项目获取dom元素宽高总是不准确问题

作者:qq_34465778 时间:2024-04-28 09:32:14 

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;

这样获取的值是有单位的。

来源:https://blog.csdn.net/qq_34465778/article/details/103991480

标签:vue,dom,元素,宽高
0
投稿

猜你喜欢

  • Python 不设计 do-while 循环结构的理由

    2021-08-04 11:55:19
  • Python列表删除重复元素与图像相似度判断及删除实例代码

    2021-02-21 05:28:58
  • 详解如何用Golang处理每分钟100万个请求

    2023-10-12 20:30:30
  • 解读ASP.NET 5 & MVC6系列教程(13):TagHelper

    2024-05-03 15:30:35
  • sqlserver 2000中创建用户的图文方法

    2024-01-18 20:02:39
  • oracle数据库创建备份与恢复脚本整理

    2023-07-13 00:57:20
  • Python的语法基础你真的了解吗

    2021-02-23 22:15:11
  • SQL SERVER 将XML变量转为JSON文本

    2024-01-21 23:38:46
  • 配置MySQL与卸载MySQL实例操作

    2024-01-19 21:55:26
  • 教你如何使用php session

    2023-11-15 06:28:01
  • Vue常用指令v-if与v-show的区别浅析

    2024-05-28 15:46:57
  • python 实现单通道转3通道

    2021-09-12 22:03:25
  • vue-week-picker实现支持按周切换的日历

    2024-04-30 10:16:23
  • python图片灰度化处理的几种方法

    2023-03-05 01:14:57
  • 总结Python编程中三条常用的技巧

    2022-06-04 05:52:04
  • 对“关于购物车的想法”的一些回复

    2009-03-10 18:15:00
  • 使用PyWeChatSpy自动回复微信拍一拍功能的实现代码

    2021-08-28 21:15:07
  • sqlserver 中时间为空的处理小结

    2024-01-13 06:07:40
  • 如何使用pyinstaller打包32位的exe程序

    2021-12-17 10:15:20
  • 你知道吗实现炫酷可视化只要1行python代码

    2022-06-10 13:36:16
  • asp之家 网络编程 m.aspxhome.com