Vue3 响应式数据最佳实践速查表

背景

ref(),reactive() ???每次记不住该用什么比较合适?

为此整理一个 Vue3 响应式数据最佳实践速查表,涵盖基础值、对象、数组、表单这几类常见场景。


📌 Vue3 响应式数据定义速查表

1. 基础值(string / number / boolean)

👉 推荐用 ref

csharp 复制代码
import { ref } from 'vue'

const count = ref(0)
const title = ref('Hello Vue3')
const isVisible = ref(true)

✅ 场景:计数器、开关、单一状态。


2. 对象(结构化数据)

👉 推荐用 reactive

php 复制代码
import { reactive } from 'vue'

const user = reactive({
  id: 1,
  name: 'Tom',
  age: 20
})

user.name = 'Jerry'   // 直接修改即可

✅ 场景:用户信息、复杂状态对象。

⚠️ 注意:不能整体替换 user = { ... },只能改属性。

👉 如果需要整体替换 → 用 ref({}) 更合适。


3. 数组(列表数据)

👉 推荐用 ref([])

csharp 复制代码
import { ref } from 'vue'

const users = ref<{ id: number; name: string }[]>([])

// 整体替换
users.value = [{ id: 1, name: 'Tom' }]

// 修改内容
users.value.push({ id: 2, name: 'Jerry' })

✅ 场景:表格、分页、查询结果(经常整体替换)。

👉 如果只修改,不会整体替换:

c 复制代码
const tags = reactive<string[]>(['vue', 'react'])
tags.push('angular')

4. 表单数据

👉 推荐用 reactive + toRefs,方便解构使用

php 复制代码
import { reactive, toRefs } from 'vue'

const form = reactive({
  username: '',
  password: '',
  remember: false
})

const { username, password, remember } = toRefs(form)

✅ 场景:登录表单、注册表单、复杂输入表单。

👉 如果表单需要 整体重置,可以这样:

php 复制代码
Object.assign(form, { username: '', password: '', remember: false })

5. DOM 引用

👉 必须用 ref

xml 复制代码
<template>
  <input ref="inputEl" />
</template>

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

const inputEl = ref<HTMLInputElement | null>(null)

onMounted(() => {
  inputEl.value?.focus()
})
</script>

✅ 总结口诀

  • 单值用 ref
  • 对象用 reactive (要整体替换就改成 ref({})
  • 数组推荐 ref([]) (便于整体替换)
  • 表单用 reactive + toRefs
  • DOM 元素用 ref

相关推荐
我命由我1234510 分钟前
HTML - 换行标签的 3 种写法(<br>、<br/>、<br />)
前端·javascript·css·html·css3·html5·js
暮冬十七15 分钟前
[特殊字符] Vue3 项目最佳实践:组件命名、目录结构与类型规范指南
前端·前端架构·vue3项目搭建
F_Director19 分钟前
简说Vue3 computed原理
前端·vue.js·面试
行走的陀螺仪28 分钟前
Flutter 开发环境配置教程
android·前端·flutter·ios
焦糖小布丁30 分钟前
代码签名证书如何有效消除Windows系统警告?
前端
icebreaker42 分钟前
重新思考 weapp-tailwindcss 的未来
前端·javascript·css
焦糖小布丁44 分钟前
为什么IP地址SSL证书比域名证书更贵?
前端
光影少年1 小时前
WEBNN是什么,对前端工程带来哪些优势
前端·web3·web
djk88881 小时前
极简后台框架
前端·css·css3
LilySesy1 小时前
ABAP+如果在join的时候需要表1的字段某几位等于表2的字段的某几位,需要怎么做?
服务器·前端·数据库·sap·abap·alv