vue3中ref与reactive具体应该怎么使用,reactive有哪些局限性

在 Vue3 中,refreactive 是 Vue3 Composition API 中两种创建响应式数据的核心工具,它们分别用于不同类型的响应式数据处理:

ref 的使用

ref 主要用于创建响应式的基本类型数据(如字符串、数字、布尔值等)或引用类型数据(如对象或数组)。当你使用 ref 时,数据会被包裹在一个带有 .value 属性的特殊对象中,访问和修改数据需要通过 .value

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

// 创建一个响应式的字符串
const count = ref(0); 
console.log(count.value); // 输出初始值 0

count.value++; // 更新值

reactive 的使用

reactive 则用于创建响应式的对象或数组,它会返回一个代理对象,可以直接对其属性进行读写,无需 .value 后缀。

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

// 创建一个响应式的对象
const user = reactive({
  name: 'John Doe',
  age: 30,
  address: {
    street: '123 Main St',
    city: 'Anytown'
  }
});

// 直接修改对象属性
user.name = 'Jane Doe';
user.address.city = 'Othertown';

reactive 的局限性

深层变更检测reactive 会对传入的对象进行深度响应式代理,这意味着其内部的嵌套对象和数组也是响应式的。然而,如果在没有Vue系统追踪的情况下,直接替换掉 reactive 对象内部某个深层次的引用,会导致新引用的数据无法自动变为响应式。例如:

ini 复制代码
 const user = reactive({ job: { title: 'Developer' } });
 user.job = { title: 'Manager' }; // 新的job对象未经过reactive处理,内部变动不会触发视图更新

要解决这个问题,应当使用 reactiveref 重新设置整个路径:

ini 复制代码
user.job = reactive({ title: 'Manager' }); // 正确做法
  1. 非对象/数组类型reactive 不适用于基本数据类型,它只能用于对象和数组。试图将非对象或非数组类型传递给 reactive 函数将导致原始数据不受响应式系统管理。

  2. Proxy限制:Vue3 的响应式系统基于 ES6 的 Proxy,而 Proxy 有一些限制,比如不能代理不可配置的属性(configurable: false)、不能代理 Symbol 类型的属性、不能代理原型链上的属性等。

共同点与差异

  • 共同点 :两者都能创建响应式数据,且在 Vue 的模板中都可以正常工作,模板会自动解包 ref.value
  • 差异
    • ref 更适合用于基本类型或单一独立的引用类型变量,它返回的是一个带有 .value 的 ref 对象。
    • reactive 用于创建包含多个属性的对象或数组结构,它返回的是一个完整的代理对象,可以直接访问和修改其属性。

在组合式API中,为了在模板或其他地方能够像普通对象一样访问 ref 的值,可以使用 toRefs 函数将 ref 对象转化为普通的响应式对象属性。

相关推荐
Shi_haoliu11 分钟前
Vue2 + Office Add-in关于用vue项目于加载项控制excel单元格内容(Demo版)
前端·javascript·vue.js·node.js·html·excel·office
计算机毕业设计木哥35 分钟前
计算机毕业设计选题推荐:基于SpringBoot和Vue的爱心公益网站
java·开发语言·vue.js·spring boot·后端·课程设计
知识分享小能手7 小时前
uni-app 入门学习教程,从入门到精通,uni-app基础扩展 —— 详细知识点与案例(3)
vue.js·学习·ui·微信小程序·小程序·uni-app·编程
MC丶科8 小时前
【SpringBoot 快速上手实战系列】5 分钟用 Spring Boot 搭建一个用户管理系统(含前后端分离)!新手也能一次跑通!
java·vue.js·spring boot·后端
90后的晨仔10 小时前
Pinia 状态管理原理与实战全解析
前端·vue.js
90后的晨仔10 小时前
Vue3 状态管理完全指南:从响应式 API 到 Pinia
前端·vue.js
90后的晨仔11 小时前
Vue 内置组件全解析:提升开发效率的五大神器
前端·vue.js
我胡为喜呀11 小时前
Vue3 中的 watch 和 watchEffect:如何优雅地监听数据变化
前端·javascript·vue.js
Sheldon一蓑烟雨任平生14 小时前
Vue3 列表渲染
vue.js·vue3·v-for·列表渲染·vue3 列表渲染·v-for 循环对象·v-for与计算属性
鹿鹿鹿鹿isNotDefined15 小时前
Pixelium Design:Vue3 的像素风 UI 组件库
前端·javascript·vue.js