在setup中使用$refs的方法
setup的第二个参数context提供了一个上下文对象,context作为上下文取代this,但是context中只有emit,attrs,和slots。
在非setup钩子中, 我们都是通过this.$refs来获取指定元素。
setup中使用this.$refs的步骤
- 定义一个ref变量, 值为null(不赋值也可以)
- 通过"return"暴露ref变量(setup语法糖的写法可以不用)
- 把变量名赋值到元素的ref属性中
1.DOM或组件设置ref属性
2.setup中使用同名变量
<template>
<h1 ref="titleRef">标题</h1>
</template>
<script setup lang="ts">
//定义一个对象关联上子组件的 ref 值(注意:这里的属性名必须跟子组件定义的 ref 值一模一样,否者会关联失效)
const titleRef = ref(null);
</script>
如果获取在指定元素时元素还没有挂载完成,使用nextTick延迟获取。
说明
存在问题:ref可以获取子组件实例,但是获取不到子组件数据
原因:组件内部数据对外关闭
解决办法:组件defineExpose()对外暴露值或方法
当函数值为指定元素时,可以采用:ref
当ref的值是一个函数的时候, 必须用:ref, 函数只有一个参数, 那就是当前元素。
<template>
<h1 :ref="getTitleRef">标题</h1>
</template>
<script setup lang="ts">
//第1步
function getTitleRef(el:HTMLElement){
console.log(el);
}
</script>
本文介绍了在Vue的setup中使用$refs的方法,包括定义ref变量、暴露变量、将变量名赋值到元素ref属性等步骤。若获取元素时未挂载完成,可延迟获取。还指出存在获取不到子组件数据的问题,原因是组件内部数据对外关闭,解决办法是组件对外暴露值或方法。
4101

被折叠的 条评论
为什么被折叠?



