100字范文,内容丰富有趣,生活中的好帮手!
100字范文 > Vue3--ref使用(解决ref无法获取dom元素的问题)

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

时间:2019-01-12 16:42:38

相关推荐

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

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

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

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

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。