在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>
相关推荐
lichenyang4537 小时前
Docker 学习笔记(一):为什么需要镜像、容器和仓库?
前端
kyriewen7 小时前
别再对着 TypeScript 报错发呆了:我把 10 个最常见的红色波浪线翻译成了人话
前端·javascript·typescript
IT_陈寒7 小时前
SpringBoot自动配置的坑,我的API突然就404了
前端·人工智能·后端
free357 小时前
从 0 实现一个 Tiny JavaScript VM:项目架构拆解
javascript
暴走的小呆8 小时前
Vue 2 中 Object 的变化侦测:从 getter/setter 到 Dep、Watcher、Observer
vue.js
奇奇怪怪的8 小时前
Embedding 模型 10+ 横向评测
前端
陈广亮8 小时前
Monorepo 从 0 到 1 实操指南 2026 版:pnpm catalogs + Turborepo 2.x + changesets 全链路
前端
子兮曰8 小时前
OpenMontage 深度解剖:你的 AI 编程助手,其实是个视频工作室
前端·后端·ai编程
敲代码的鱼8 小时前
PDF 预览与签名批注写回 支持安卓 iOS 鸿蒙 UTS插件
android·前端·ios