news 2026/6/26 21:22:58

深入理解ref、reactive【Vue3工程级指南】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
深入理解ref、reactive【Vue3工程级指南】

这篇文章的目标只有一个:让你在任何场景下,都能毫不犹豫地判断:这个地方该用ref,还是reactive

目录

  • 响应式的本质不是变量
  • ref 是什么?什么时候该用 ref?
    • ref 的本质
    • 什么时候必须用 ref(重点)
      • 场景 1:基本类型
      • 场景 2:对象 / 数组会被整体替换
      • 场景 3:对象是“状态”,而不是“模型”
    • ref 的优缺点
  • reactive 是什么?什么时候该用 reactive?
    • reactive 的本质
    • 什么时候 reactive 是最优解
      • 场景 1:表单对象
      • 场景 2:长期存在的业务模型
    • reactive 的优缺点
  • 对象到底用 ref 还是 reactive?
  • 响应式是怎么“失去”的
    • reactive 失效的三大原因
    • ref 失效的常见原因
  • toRef / toRefs:解决解构问题
    • toRef 是什么
    • toRefs 批量使用
  • 总结

响应式的本质不是变量

在 Vue3 里,响应式的本质不是变量,而是“引用关系”

  • ref用一个对象包住一个值,通过 .value 访问
  • reactive用 Proxy 代理一个对象

⚠️:Vue 追踪的不是变量名,而是 ref.value 或 Proxy 内部的属性访问

ref 是什么?什么时候该用 ref?

ref 的本质

constcount=ref(0)
  • count 是一个对象
  • 真正的值在 count.value
  • Vue 通过 getter / setter 追踪 .value

在模板里:

{{count}}// 自动解包

在js/ts中:

count.value++

什么时候必须用 ref(重点)

场景 1:基本类型

constloading=ref(false)constpage=ref(1)constkeyword=ref('')

场景 2:对象 / 数组会被整体替换

constlist=ref<Item[]>([])list.value=res.data

如果用 reactive:

constlist=reactive([])list=res.data// ❌ 直接失效

只要你会写 = 重新赋值,就用 ref!!!

场景 3:对象是“状态”,而不是“模型”

什么是状态,什么是模型???

constcurrentRow=ref<Row|null>(null)
  • 有 / 没有
  • 选中 / 取消
  • 打开 / 关闭

这是状态,不是业务结构

ref 的优缺点

优点:

  • 可以整体替换
  • 可以为 null / undefined
  • 解构安全
  • 状态语义清晰

缺点:

  • JS 中需要 .value
  • 对象层级深时略显啰嗦

reactive 是什么?什么时候该用 reactive?

reactive 的本质

constform=reactive({name:'',age:18})
  • 返回的是一个 Proxy
  • 每个属性访问都会被 Vue 追踪
  • 没有 .value

什么时候 reactive 是最优解

场景 1:表单对象

constform=reactive({name:'',age:0,role:''})

原因:

  • 字段多
  • 高频修改单字段
  • v-model 非常频繁
  • 不需要整体替换

场景 2:长期存在的业务模型

conststate=reactive({loading:false,page:1,pageSize:10})

这些数据:

  • 生命周期一致
  • 逻辑上属于一组
  • 不会被整体重置

reactive 的优缺点

优点:

  • 写法自然
  • 表单 / v-model 体验极佳
  • 代码可读性高

缺点:

  • ❌ 不能整体替换
  • ❌ 不能为 null
  • ❌ 解构会丢响应式

对象到底用 ref 还是 reactive?

四个问题法(直接用)

refreactive
会不会被整体替换会 -> ref不会 -> reactive
关心"对象是谁"or"字段怎么变"?是谁 -> ref字段 -> reactive
会不会大量 v-model会 -> reactive
是不是长期业务模型是 -> reactive

响应式是怎么“失去”的

reactive 失效的三大原因

form=newForm// ❌ 整体替换const{name}=form// ❌ 解构JSON.parse(JSON.stringify(form))// ❌ 深拷贝

正确做法:

Object.assign(form,newForm)

ref 失效的常见原因

constc=count.value// ❌ 断开引用

因为这里只是把count这个响应式的值给了c而已

toRef / toRefs:解决解构问题

toRef 是什么

constname=toRef(form,'name')
  • 把 reactive 的某个字段变成 ref
  • 双向同步

toRefs 批量使用

const{name,age}=toRefs(form)

它们的原理都是 把reactive内的变量都解构成响应式的ref包裹的变量

总结

  • reactive 负责“结构”
  • ref 负责“状态”
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/26 8:28:51

毕设 stm32 RFID员工打卡门禁系统(源码+硬件+论文)

文章目录 0 前言1 主要功能2 硬件设计(原理图)3 核心软件设计4 实现效果5 最后 0 前言 &#x1f525; 这两年开始毕业设计和毕业答辩的要求和难度不断提升&#xff0c;传统的毕设题目缺少创新和亮点&#xff0c;往往达不到毕业答辩的要求&#xff0c;这两年不断有学弟学妹告诉…

作者头像 李华
网站建设 2026/6/24 18:46:14

全球最大、最领先的吉利全球全域安全中心正式发布

12月12日&#xff0c;吉利全球全域安全中心正式发布&#xff0c;并一举创下“全球最大的汽车安全试验室”、“全球最长的室内汽车碰撞测试跑道”、“全球最大的汽车环境风洞试验室”、“全球最大的任意角度汽车碰撞测试区&#xff08;0-180&#xff09;”、“全球测试功能最多的…

作者头像 李华
网站建设 2026/6/25 18:31:20

Android中Compose系列之按钮Button

文章目录前言一、Button的基本使用1.Button2.扩展TextButtonOutlinedButtonIconButton二、Button属性前言 Button是Compose中作为按钮提供交互的控件&#xff0c;它本身属性自带onClick的点击处理&#xff0c;不需要使用Modifiter中的点击功能&#xff0c;目前最新版默认按钮风…

作者头像 李华
网站建设 2026/6/26 16:23:16

wangEditor导入excel数据到html富文本编辑

在数字化浪潮的推动下&#xff0c;省博物馆的网站已成为展示文化瑰宝、传播历史文化的重要窗口。为了进一步提升网站内容更新的效率与质量&#xff0c;满足多样化信息展示需求&#xff0c;现针对网站后台编辑器提出增加 Word 导入功能的需求&#xff0c;具体说明如下&#xff1…

作者头像 李华
网站建设 2026/6/25 18:18:49

JSP中如何利用分块技术实现百万文件上传优化?

大文件传输系统技术方案 需求分析与技术挑战 作为深圳软件有限公司的项目负责人&#xff0c;我们深入分析了贵公司对大文件传输系统的需求&#xff0c;主要面临以下技术挑战&#xff1a; 超大文件处理&#xff1a;单文件100G的高效传输文件夹结构保留&#xff1a;完整保留层…

作者头像 李华