在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>
相关推荐
凌览12 小时前
一键去水印|5 款免费小红书解析工具推荐
前端·javascript·后端
有意义12 小时前
栈数据结构全解析:从实现原理到 LeetCode 实战
javascript·算法·编程语言
lichong95112 小时前
鸿蒙 web组件开发
前端·typescript
1024小神12 小时前
在html中使用js动态交换两个元素的位置
前端
鹿鹿鹿鹿isNotDefined12 小时前
逐步手写,实现符合 Promise A+ 规范的 Promise
前端·javascript·算法
一千柯橘12 小时前
Electron - IPC 解决主进程和渲染进程之间的通信
前端
申阳12 小时前
Day 16:02. 基于 Tauri 2.0 开发后台管理系统-项目初始化配置
前端·后端·程序员
老前端的功夫12 小时前
HTTP 协议演进深度解析:从 1.0 到 2.0 的性能革命
前端·网络·网络协议·http·前端框架
拉不动的猪12 小时前
前端三大权限场景全解析:设计、实现、存储与企业级实践
前端·javascript·面试
wordbaby13 小时前
Flutter Form Builder 完全指南:告别 Controller 地狱
前端·flutter