vue 获取 指定元素的高度宽度等(使用vue中的 ref 获取到的是 dom 元素高度或者宽度)

本文介绍在Vue中如何利用ref属性获取DOM元素的尺寸信息,包括宽度、高度及带有单位的数值。通过实例展示了如何使用offsetHeight、offsetWidth等属性,并提供了获取样式高度的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用 vue 的时候,想要获得一个指定的元素的高度时,可以使用 vue 中的 ref 。

当 ref 加在普通的元素上,使用 this.ref.name 获取到的是 dom 元素

示例

写在 页面 html 部分的

<div ref="init"></div> 

写在 页面 方法 部分

这里的 offsetHeight 是返回元素的宽度(包括元素宽度、内边距和边框,不包括外边距)

let height= this.$refs.init.offsetHeight;  

这里的offsetHeight可以替换,用来获取其他的属性

offsetWidth       //返回元素的宽度(包括元素宽度、内边距和边框,不包括外边距)

offsetHeight      //返回元素的高度(包括元素高度、内边距和边框,不包括外边距)

clientWidth        //返回元素的宽度(包括元素宽度、内边距,不包括边框和外边距)

clientHeight       //返回元素的高度(包括元素高度、内边距,不包括边框和外边距)

style.width         //返回元素的宽度(包括元素宽度,不包括内边距、边框和外边距)

style.height       //返回元素的高度(包括元素高度,不包括内边距、边框和外边距)

scrollWidth       //返回元素的宽度(包括元素宽度、内边距和溢出尺寸,不包括边框和外边距),无溢出的情况,与clientWidth相同

scrollHeigh       //返回元素的高度(包括元素高度、内边距和溢出尺寸,不包括边框和外边距),无溢出的情况,与clientHeight相同

除此之外,还可以获取带有单位的数值

let height = window.getComputedStyle(this.$refs.init).height; 

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

smile_hahahaxixi 同学提示下,已经修改。

### 在 Vue3 中使用 `ref` 获取 DOM 元素高度 为了在 Vue3 中获取 DOM 元素高度,可以通过组合式 API 的方式来操作。具体来说,在模板中定义带有 `ref` 属性的 HTML 元素,并在 `<script setup>` 或者选项式的 `<script>` 部分初始化对应的响应式引用变量。 当组件挂载完成后,即可以在生命周期钩子函数 `onMounted` 内部访问到这个元素并读取其高度属性: ```html <template> <div ref="mains" class="search"></div> </template> <script setup lang="ts"> import { ref, onMounted } from 'vue' const mains = ref(null) onMounted(() => { if (mains.value) { const height = mains.value.clientHeight console.log('Element Height:', height) } }) </script> <style scoped lang="less"> .search { width: 100px; height: 100px; margin: 0 auto; background-color: greenyellow; } </style> ``` 上述代码展示了如何声明一个名为 `mains` 的响应式引用对象用于存储目标 DOM 节点[^1]。一旦页面加载完毕并且组件成功渲染至浏览器文档流之后,就会触发 `onMounted()` 生命周期回调,在这里可以直接通过 `.value` 访问实际的 DOM 对象进而调用它的原生 JavaScript 方法或属性比如 `clientHeight` 来取得当前元素可视区域内的真实尺寸[^2]。 值得注意的是,由于 TypeScript 类型推断机制的存在,最好为 `ref()` 明确指定预期的数据类型以避免潜在错误;另外还需注意检查 `mains.value !== null && mains.value !== undefined` ,防止未及时更新导致的操作失败情况发生[^3]。
评论 8
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值