Vue3--ref使用(解决ref无法获取dom元素的问题)

本文详细介绍Vue3中ref的两种主要用途:一是作为响应式数据监听工具,尤其适用于基本数据类型;二是作为模板ref来获取DOM元素节点。文章还解决了无法在setup阶段直接获取DOM节点的问题。

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

众所周知在vue2中,ref主要的作用还是便于快速的获取dom元素或组件,因为ref操作相比document.getElementbyId会减少dom操作的节点消耗。

具体关于vue2中ref和$refs的使用,这篇文章写的十分全面:

https://www.cnblogs.com/xumqfaith/p/7743387.html

本文还是针对Vue3中ref使用进行说明,重点是模板ref的使用。

1. ref用法1:基本类型封装,使数据响应式

vue3中为了节约资源,并不是全部数据都会进行响应式监听。他允许用户进行动态监听。

因此在vue3中主要用reactive和ref进行响应数据的监听。他俩的区别在于:

①reactive中必须存放对象(json、数组等),不能存放基本数据类型

②ref则可以存放基本数据类型【注:ref本质还是reactive】

举例:

let a=reactive({a:5});

let b=ref(5);

详细使用请参考官方文档!

Vue3中文文档

2.ref用法2:模板ref,获取dom元素节点(重点

①const a=ref(null);

②在template中定义ref

   <div ref='a'>*********</div>

③setup中获取对应节点【在onMounted里】

④将a return出去;

但是这时候你可能会发现,你无法获取这个节点。例如下面的代码段,你无法获取video节点。

<!-- videocontainer -->
<template>
    <div class="video-container">
      <video :src="props.src" ref="V1" style='top:0px' loop playsinline muted></video>
    </div>
</template>
<script>
//这里可以导入其他文件(比如:组件,工具js,第三方插件js,json文件,图片文件等等)
//例如:import 《组件名称》 from '《组件路径》';
import {onMounted,ref} from 'vue';
export default {
  props:['src'],
  setup(props,context){
    const V1=ref(null);
    console.log('节点',V1.value);
    return{
      props,V1,
    }
})
</script>

浏览器显示结果:

这是什么原因呢?

其实还是生命周期的问题,结合官方文档可知:原来的created没有了,setup充当了原来的created。

 

Vue3生命周期钩子 

所以在setup的时候,dom元素还没有被创建,一切都处于混沌状态,只有setup完毕了HTML才能完整构建,才能真正访问到value值,所以自然无法获取到dom节点,要想解决这个问题,就要配合钩子函数,在dom挂载完毕后再进行获取,更改上述代码后如下:

<!-- videocontainer -->
<template>
    <div class="video-container">
      <video :src="props.src" ref="V1" style='top:0px' loop playsinline muted></video>
    </div>
</template>

<script>
//这里可以导入其他文件(比如:组件,工具js,第三方插件js,json文件,图片文件等等)
//例如:import 《组件名称》 from '《组件路径》';
import {onMounted,ref} from 'vue';
export default {
  props:['src'],
  setup(props,context){
    const V1=ref(null);
    onMounted(()=>{
        console.log(V1.value);
    })
    return{
      props,V1,
    }
  },
}
</script>

结果如下: 可以获取到dom元素了。

3.总结:

通过本文主要解决两个问题:一是在vue3中如何用模板ref获取dom元素,二是解决获取不到节点的问题。欢迎大佬们留言补充指正。

### Vue 3使用 `ref` 获取 DOM 元素并操作其样式 在 Vue 3 中,可以利用 Composition API 提供的 `ref` 函数来创建响应式的引用对象,并通过这些引用访问真实的 DOM 节点及其属性。当目标是在挂载阶段之后修改特定元素的内联样式时,可以在生命周期钩子函数如 `onMounted()` 内部执行相应逻辑。 下面是一个具体的例子展示如何设置和改变某个 div 的背景颜色: ```html <template> <div ref="styledDiv">这个方框的颜色会变化</div> </template> <script> import { ref, onMounted } from &#39;vue&#39;; export default { setup() { const styledDiv = ref(null); onMounted(() => { // 修改DOM元素的style属性 styledDiv.value.style.backgroundColor = "lightblue"; console.log(styledDiv.value.style); }); return { styledDiv, }; }, }; </script> <style scoped> /* 初始样式 */ div { width: 200px; height: 200px; } </style> ``` 此代码片段展示了如何定义一个名为 `styledDiv` 的引用变量指向模板中的 `<div>` 元素,在组件完成渲染后 (`onMounted`) 更改该元素的背景色为浅蓝色[^1]。 对于更复杂的场景下可能需要等待下一个 DOM 更新周期再读取或更新样式的情况,则可借助于 `nextTick` 方法实现延迟处理: ```javascript import { ref, nextTick } from &#39;vue&#39;; // ... const changeStyleLater = async () => { await nextTick(); styledDiv.value.style.borderRadius = "50%"; }; changeStyleLater(); ``` 上述方法确保了样式的更改发生在所有的状态变更被应用到 DOM 后立即发生[^2]。
评论 28
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

韦_恩

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值