浅记Vue3中 ref 和 reactive 是两种主要的响应式数据声明方式,它们有以下主要区别

1. 声明方式

ref:可以包装任何类型的值(基本类型、对象、数组等)

const count = ref(0) // 基本类型

const obj = ref({ name: 'John' }) // 对象

const arr = ref(1, 2, 3) // 数组

reactive:只能用于对象类型(对象、数组、Map、Set等)

const obj = reactive({ name: 'John' })

const arr = reactive(1, 2, 3)

2. 访问方式

ref:需要通过 .value 访问和修改

const count = ref(0)

console.log(count.value) // 读取

count.value = 1 // 修改

reactive:直接访问属性

const state = reactive({ count: 0 })

console.log(state.count) // 读取

state.count = 1 // 修改

3. 模板中使用

ref:在模板中自动解包,无需 .value

reactive:直接使用属性

4. 响应式

ref:是一个响应式的 ref 对象,当它的值发生变化时,会触发相应的更新

reactive:是一个响应式的对象,当它的属性发生变化时,会触发相应的更新

5. 深度响应

ref:默认不会深度响应,即对嵌套对象的修改不会触发更新

reactive:默认会深度响应,即对嵌套对象的修改会触发更新

6. 性能

ref:对于基本类型的响应式,ref 通常比 reactive 更轻量级,因为它不需要额外的代理和追踪

reactive:对于复杂的对象,reactive 通常更高效,因为它可以自动追踪所有的属性变化

7. 注意事项

ref:在模板中使用时,需要解包 .value

reactive:在模板中直接使用属性

8. 总结

选择使用 ref 还是 reactive 取决于具体的需求:

如果需要一个基本类型的响应式,可以使用 ref

如果需要一个复杂的对象的响应式,可以使用 reactive

一般来说,对于简单的数据,ref 更适合,而对于复杂的数据,reactive 更适合。

选择合适的响应式方式可以提高代码的可读性和性能。

相关推荐
JustHappy7 小时前
古法编程秘籍(七):互联网到底是什么?把两台电脑怎么说话搞懂就够了
前端·后端·网络协议
老毛肚7 小时前
jeecg-boot-base-core 02 day
javascript·python
snow@li7 小时前
SEO-文章标题:写文章时候,分类+主标题+大纲+解释 作为标题 / 不点进去也知道全文覆盖什么 / 标题即架构
前端
kyriewen8 小时前
Git Commit 前自动修复代码风格?配置 Husky + lint-staged,从此 CR 只聊逻辑
前端·git·面试
岁月宁静8 小时前
RAG 文档摄入全链路,从原理到生产落地
vue.js·人工智能·python
小和尚同志8 小时前
AI 自动化测试探索(一):Playwright MCP
前端·人工智能·aigc
老马识途2.08 小时前
在AI的帮助下理解spring的启动过程
java·前端·spring
徐小夕9 小时前
Loop Engineering 深度解析与实战指南(全网最全)
前端·算法·github
运筹vivo@9 小时前
Python ContextVar 底层机制与内存模型拆解
前端·数据库·python
#麻辣小龙虾#10 小时前
基于vue3.0开发一款【固废与废气运维管理系统】(支持源码)
前端·vue.js·vue3