Vue3 |
您所在的位置:网站首页 › 无法读取未定义的属性该怎么操作 › Vue3 |
众所周知在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节点。 //这里可以导入其他文件(比如:组件,工具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, } })浏览器显示结果: 这是什么原因呢? 其实还是生命周期的问题,结合官方文档可知:原来的created没有了,setup充当了原来的created。
Vue3生命周期钩子 所以在setup的时候,dom元素还没有被创建,一切都处于混沌状态,只有setup完毕了HTML才能完整构建,才能真正访问到value值,所以自然无法获取到dom节点,要想解决这个问题,就要配合钩子函数 结果如下: 可以获取到dom元素了。 通过本文主要解决两个问题:一是在vue3中如何用模板ref获取dom元素,二是解决获取不到节点的问题。欢迎大佬们留言补充指正。 |
今日新闻 |
推荐新闻 |
CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3 |