在setup中使用$refs的方法

在setup中使用$refs的方法

setup的第二个参数context提供了一个上下文对象,context作为上下文取代this,但是context中只有emitattrs,和slots

在非setup钩子中, 我们都是通过this.$refs来获取指定元素。
setup中使用this.$refs的步骤

  1. 定义一个ref变量, 值为null
  2. 通过"return"暴露ref变量(setup语法糖的写法可以不用)
  3. 把变量名赋值到元素的ref属性中
js 复制代码
<template>
	<!-- 第3步-->
  <h1 ref="titleRef">标题</h1>
</template>
<script setup lang="ts">
//定义一个对象关联上子组件的 ref 值(注意:这里的属性名必须跟子组件定义的 ref 值一模一样,否者会关联失效)
const titleRef = ref(null);
</script>

如果获取在指定元素时元素还没有挂载完成,使用nextTick延迟获取。

当函数值为指定元素时,可以采用:ref

当ref的值是一个函数的时候, 必须用:ref, 函数只有一个参数, 那就是当前元素。

js 复制代码
<template>
	<!-- 第3步-->
  <h1 :ref="getTitleRef">标题</h1>
</template>
<script setup lang="ts">
//第1步
function getTitleRef(el:HTMLElement){
    console.log(el);
}

</script>
相关推荐
Shi_haoliu6 小时前
openClaw源码部署-linux
前端·python·ai·openclaw
程序员小寒6 小时前
前端性能优化之白屏、卡顿指标和网络环境采集篇
前端·javascript·网络·性能优化
烛阴6 小时前
Claude CLI AskUserQuestion 工具详解:让 AI 开口问你
前端·claude
wal13145207 小时前
OpenClaw教程(九)—— 彻底告别!OpenClaw 卸载不残留指南
前端·网络·人工智能·chrome·安全·openclaw
mon_star°7 小时前
在TypeScript中,接口MenuItem定义中,为什么有的属性带问号?,有的不带呢?
前端
牛奶7 小时前
分享一个开源项目,让 AI 辅助开发真正高效起来
前端·人工智能·全栈
次顶级8 小时前
表单多文件上传和其他参数处理
前端·javascript·html
kuntli8 小时前
Vue生命周期全解析
vue.js
why技术8 小时前
我拿到了腾讯QClaw的内测码,然后沉默了。
前端·后端