vue ref

‌‌Vue中的‌ref主要用于创建响应式变量和直接访问DOM元素/组件实例‌,是Vue响应式系统的核心API之一。

Vue ref的核心功能

‌1、响应式数据管理‌:

  • 通过ref()函数将基本类型或复杂类型数据转化为响应式对象,数据变更自动触发视图更新。‌‌
  • 组合式API中必须通过.value属性操作数据(如const count = ref(0); count.value++)。‌‌

2‌、DOM与组件操作‌:

  • 在模板中通过ref="xxx"标记元素,通过this.$refs.xxx直接获取DOM节点(Vue 2)或组件实例。‌‌
  • ‌Vue 3中使用<script setup>时,需通过const el = ref(null)声明引用

使用场景示例

  • ‌‌表单验证‌:通过ref获取输入框DOM实时校验内容。
  • ‌‌动画控制‌:直接操作DOM元素的样式属性实现复杂动画。
  • ‌‌组件通信‌:父组件通过ref调用子组件暴露的方法(如this.$refs.child.validateForm())。‌‌

用在普通DOM标签上:

复制代码
<template>

  <h1 ref="title1"> 中国</h1>
  <h2 ref="title2"> 河南</h2>
  <h3 ref="title3"> 洛阳</h3>
  <input type="text" ref="inpt"> <br><br>
  <button @click="showLog">点我打印内容</button>
</template>

<script lang="ts" setup>
import { ref } from 'vue'

let title1 = ref()
let title2 = ref()
let title3 = ref()

function showLog() {
  // 通过id获取元素
  const t1 = document.getElementById('title1')
  if (t1) {
    t1.innerText = "新的文本";
    // 打印内容
    console.log((t1 as HTMLElement).innerText)
    console.log((<HTMLElement>t1).innerText)
    console.log(t1?.innerText)
  } else {
    console.log("元素未找到");
  }

  // 通过ref获取元素
  console.log(title1.value)
  console.log(title2.value)
  console.log(title3.value)
}
</script>

用在组件标签上:

复制代码
<!-- 父组件App.vue -->
<template>
  <Person ref="ren"/>
  <button @click="test">测试</button>
</template>

<script lang="ts" setup name="App">
  import Person from './components/Person.vue'
  import {ref} from 'vue'

  let ren = ref()

  function test(){
    console.log(ren.value.name)
    console.log(ren.value.age)
  }
</script>


<!-- 子组件Person.vue中要使用defineExpose暴露内容 -->
<script lang="ts" setup name="Person">
  import {ref,defineExpose} from 'vue'
	// 数据
  let name = ref('张三')
  let age = ref(18)
  /****************************/
  /****************************/
  // 使用defineExpose将组件中的数据交给外部
  defineExpose({name,age})
</script>
相关推荐
lbh12 小时前
当我开始像写代码一样和AI对话,一切都变了
前端·openai·ai编程
We་ct13 小时前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
qq_4061761413 小时前
深入浅出 Pinia:Vue3 时代的状态管理新选择
javascript·vue.js·ecmascript
wefly201714 小时前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
C澒14 小时前
微前端容器标准化 —— 公共能力篇:通用打印
前端·架构
德育处主任Pro14 小时前
前端元素转图片,dom-to-image-more入门教程
前端·javascript·vue.js
木斯佳15 小时前
前端八股文面经大全:小红书前端一二面OC(下)·(2026-03-17)·面经深度解析
前端·vue3·proxy·八股·响应式
陈天伟教授15 小时前
人工智能应用- 预测新冠病毒传染性:04. 中国:强力措施遏制疫情
前端·人工智能·安全·xss·csrf
叫我一声阿雷吧15 小时前
JS 入门通关手册(23):JS 异步编程:回调函数与异步本质
javascript·es6·前端面试·回调函数·回调地狱·js异步编程·异步本质
zayzy15 小时前
前端八股总结
开发语言·前端·javascript