在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>
相关推荐
果壳~几秒前
【Uniapp】【rich-text】富文本展示以及图片预览功能解决方案
前端·javascript·uni-app
z19408920662 分钟前
在线生成背景:字号层级怎么做才像「正式物料」
前端·javascript·html
skilllite作者5 分钟前
GEO 是什么:从搜索引擎到「对话式答案」的信息可见性
java·前端·笔记·安全·搜索引擎·agentskills
Hello--_--World9 分钟前
React:useState 函数式更新、useContext 全解析、useReducer 深度解析
前端·react.js·前端框架
李白的天不白11 分钟前
vue优化建议
前端·javascript·vue.js
前端老石人14 分钟前
Chrome DevTools 调试入门:从零开始排查 CSS 问题
前端·css·chrome devtools
恋猫de小郭18 分钟前
经典,Flutter iOS 又修复了一个构建问题,还是很抽象
android·前端·flutter
invicinble22 分钟前
前端框架使用vue-cli(总篇章介绍)
前端·vue.js·前端框架
QD_ANJING26 分钟前
普及一下五月AI前端面试需要达到的强度....
前端·javascript·vue.js·人工智能·面试·职场和发展
AI自动化工坊27 分钟前
Chrome DevTools MCP:让AI编码代理获得浏览器调试能力
前端·人工智能·chrome devtools