在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>
相关推荐
Smoothcloud润云11 小时前
告别 Selenium:Playwright 现代 Web 自动化测试从入门到实战
前端·人工智能·selenium·测试工具·架构·自动化
前端小D11 小时前
ES6 中的 Promise
前端·javascript·es6·promise
光影少年11 小时前
React和Vue的区别?
前端·vue.js·react.js
遗憾随她而去.11 小时前
前端跨页面通信:8 种方案全解析(附实战案例)
前端
何中应11 小时前
<el-tag>标签使用
前端·vue.js·elementui
清汤饺子11 小时前
Cursor 独有的 12 个技巧:这些是 Claude Code 没有的
前端·后端·ai编程
白菜__11 小时前
阿里V2滑块小程序版本
javascript·爬虫·网络协议·小程序·node.js
Mr数据杨12 小时前
【Dv3Admin】FastCRUD富文本编辑器操作
前端·javascript
倾颜12 小时前
零成本本地大模型!用 Next.js + Ollama + Qwen3 打造流式聊天应用
前端·后端·ai编程
英俊潇洒美少年12 小时前
react useDeferredValue和useTransition有啥区别
javascript·react.js·ecmascript