vue中的ref属性与nextTick

Vue 3 中 refnextTick 使用整理


ref 的两种使用方式

1. ref() 用于创建响应式数据

csharp 复制代码
 jsCopyEditimport { ref } from 'vue'
 ​
 const count = ref(0)
 count.value++ // 注意使用 .value

2. ref="xxx" 用于获取 DOM 或组件实例引用

xml 复制代码
 vueCopyEdit<template>
   <input ref="inputRef" />
 </template>
 ​
 <script setup>
 import { ref, onMounted } from 'vue'
 ​
 const inputRef = ref(null)
 ​
 onMounted(() => {
   inputRef.value.focus() // 获取 DOM 节点并调用方法
 })
 </script>

ref="inputRef" 绑定到 DOM 或子组件,配合 <script setup> 中的 ref(null) 一起使用。


组合式 API 中访问子组件的方法

使用 ref + defineExpose

子组件
xml 复制代码
 vueCopyEdit<script setup>
 const sayHello = () => console.log("Hello")
 defineExpose({ sayHello })
 </script>
父组件
xml 复制代码
 vueCopyEdit<Child ref="childRef" />
 <button @click="childRef?.sayHello()">调用子组件</button>
 ​
 <script setup>
 import { ref } from 'vue'
 import Child from './Child.vue'
 ​
 const childRef = ref(null)
 </script>

nextTick() 的作用和使用

作用:

等待 DOM 更新完成后 再执行某段逻辑。

常用场景:

  • 等待 v-if 切换 DOM 后获取或操作 DOM
  • 等待响应式数据更新完成后做副作用
  • 设置 input.focus()

使用方式

javascript 复制代码
 import { nextTick } from 'vue'
 ​
 nextTick(() => {
   // 此处 DOM 已更新
   console.log('DOM updated')
 })

或:

csharp 复制代码
const edit = async () => {
  isShow.value = false
  await nextTick()
  inputRef.value?.focus()
}

🧪 示例:点击按钮显示输入框并自动聚焦

xml 复制代码
 vueCopyEdit<template>
   <div v-if="isShow">
     {{ msg }}
     <button @click="edit">编辑</button>
   </div>
   <div v-else>
     <input ref="inputRef" />
     <button @click="end">完成</button>
   </div>
 </template>
 ​
 <script setup>
 import { ref, nextTick } from 'vue'
 ​
 const isShow = ref(true)
 const msg = ref("hello")
 const inputRef = ref(null)
 ​
 const edit = async () => {
   isShow.value = false
   await nextTick()
   inputRef.value?.focus()
 }
 ​
 const end = () => {
   isShow.value = true
 }
 </script>

总结:

ref="xxx" 用于获取 DOM/组件,nextTick() 用于等待 DOM 更新后执行操作。

相关推荐
我是Superman丶4 小时前
Element UI 表格某行突出悬浮效果
前端·javascript·vue.js
Cobyte8 小时前
3.响应式系统基础:从发布订阅模式的角度理解 Vue2 的数据响应式原理
前端·javascript·vue.js
军军君019 小时前
Three.js基础功能学习十八:智能黑板实现实例五
前端·javascript·vue.js·3d·typescript·前端框架·threejs
禅思院9 小时前
前端架构演进:基于AST的常量模块自动化迁移实践
前端·vue.js·前端框架
许杰小刀9 小时前
FastAPI + Vue 前后端分离实战:我的项目结构“避坑指南”
前端·vue.js·fastapi
walking9579 小时前
Vue3 日历组件选型指南:五大主流方案深度解析
前端·vue.js·面试
英俊潇洒美少年9 小时前
Vue、React.lazy、React 19 异步组件核心区别
javascript·vue.js·react.js
快乐小土豆~~10 小时前
echarts柱状图的X轴label过长被重叠覆盖
前端·javascript·vue.js·echarts
儒雅的烤地瓜10 小时前
Vue | Vue3中<script setup>用法详解
vue.js·vue3·选项式api·组合式 api·setup方法·<script setup>
小李子呢021110 小时前
前端八股2---Proxy 代理
前端·javascript·vue.js