Vue 3 中的 ref 和 reactive

🚀 Vue 3 中的refreactive :一篇搞懂! 🚀

在 Vue 3 中,refreactive 是创建响应式数据的两种主要方式。它们有什么区别?该如何选择?今天我们就来彻底搞懂这两个 API!👇


1. ref 是什么?

ref 是 Vue 3 提供的一个函数,用于创建一个 响应式引用

1.1 特点

  • 可以包装任意类型的值(包括基本类型和对象)。
  • 通过 .value 访问和修改值。
  • 适合用于 单个值 的响应式数据。

1.2 示例

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

const count = ref(0); // 创建一个响应式引用

console.log(count.value); // 访问值
count.value++; // 修改值

2. reactive 是什么?

reactive 是 Vue 3 提供的一个函数,用于创建一个 响应式对象

2.1 特点

  • 只能包装对象(包括数组和复杂对象)。
  • 直接访问和修改对象的属性。
  • 适合用于 复杂对象 的响应式数据。

2.2 示例

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

const state = reactive({
  count: 0,
  name: 'Alice',
});

console.log(state.count); // 访问属性
state.count++; // 修改属性

3. ref reactive的区别

特性 ref reactive
包装类型 任意类型(基本类型、对象) 只能包装对象
访问方式 通过 .value访问 直接访问属性
适用场景 单个值(如数字、字符串) 复杂对象(如表单、状态管理)
性能 适合简单数据 适合复杂数据

4. 如何选择 ref reactive

4.1 使用 ref 的场景

  • 单个值(如计数器、开关状态)。
  • 需要明确区分响应式数据和非响应式数据。

示例

ini 复制代码
const count = ref(0);
const isActive = ref(false);

4.2 使用 reactive 的场景

  • 复杂对象(如表单数据、状态管理)。
  • 需要直接访问和修改对象的属性。

示例

php 复制代码
const form = reactive({
  username: '',
  password: '',
});

const user = reactive({
  name: 'Alice',
  age: 25,
});

5. ref reactive 的互相转换

5.1 ref reactive

可以将 ref 包装的对象传递给 reactive

示例

ini 复制代码
const count = ref(0);
const state = reactive({ count });

console.log(state.count); // 访问值
state.count++; // 修改值

5.2 reactive ref

可以使用 toRefsreactive 对象的属性转换为 ref

示例

scss 复制代码
const state = reactive({ count: 0 });
const { count } = toRefs(state);

console.log(count.value); // 访问值
count.value++; // 修改值

6. 总结

  • ref:适合用于单个值的响应式数据,通过 .value 访问和修改。
  • reactive:适合用于复杂对象的响应式数据,直接访问和修改属性。
  • 选择依据:根据数据的复杂度和使用场景选择合适的 API。

如果你对 refreactive 还有疑问,欢迎在评论区讨论!💬

相关推荐
LaughingZhu17 小时前
Product Hunt 每日热榜 | 2026-06-10
前端·人工智能·经验分享·chatgpt·html
打小就很皮...17 小时前
基于 Python + LangChain + React 实现智能发票识别与验真系统实战
前端·react.js·langchain·ocr·发票识别
惢雨17 小时前
ts中的特殊符号说明并举例,如 ?. 、?:、??等
前端·typescript
小此方17 小时前
【别传:Web前端开发(三)】重塑动态视界:JS底层逻辑、数据类型流转与WebAPI交互全景草稿
前端·javascript·交互
粉末的沉淀17 小时前
css:隐藏video标签的下载按钮
前端·css
仰望.17 小时前
vue表格使用 vxe-table 展开行实现产品列表与明细列表
前端·javascript·vue.js·vxe-table
AI人工智能+电脑小能手17 小时前
【大白话说Java面试题 第107题】【并发篇】第7题:说说 Lock 锁?
java·开发语言·面试
H1785350909617 小时前
SolidWorks_基于草图的实体特征14_扫描扭转与控制
前端·人工智能·算法·3d建模·solidworks
万岳科技系统开发17 小时前
骑手配送系统如何支持外卖与跑腿一体化运营
大数据·前端·小程序
雨季mo浅忆17 小时前
Cursor快速实现上传Excel功能
前端·vue3·ai编程