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

  • Post author:
  • Post category:vue


众所周知在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


*********


③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元素,二是解决获取不到节点的问题。欢迎大佬们留言补充指正。



版权声明:本文为web15285868498原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。