【前端】【面试】ref与reactive的区别

refreactive 的区别笔记

一、概述

在 Vue 3 的组合式 API 中,refreactive 是两个非常重要的响应式工具,它们都用于创建响应式数据,但在使用方式、适用场景和内部实现上存在一些区别。

二、基本使用方式

1. ref

ref 用于创建一个响应式的引用对象,它可以接收任何类型的值,包括基本数据类型(如 numberstringboolean 等)和对象类型。通过 .value 属性来访问和修改其值。当传入对象时,ref 内部实际上会使用 reactive 对该对象进行处理以实现响应式。

js 复制代码
<template>
  <div>
    <p>{{ person.value.name }}</p>
    <button @click="changeName">Change Name</button>
  </div>
</template>

<script setup>
import { ref } from 'vue';

// 创建一个包含对象的 ref
const person = ref({
  name: 'John'
});

const changeName = () => {
  // 修改 ref 中对象的属性
  person.value.name = 'Jane';
};
</script>

2. reactive

reactive 用于创建一个响应式的对象,它只能接收对象类型的值(包括普通对象、数组、Map、Set 等),并且不需要通过 .value 来访问和修改其属性。

js 复制代码
<template>
  <div>
    <p>{{ state.name }}</p>
    <button @click="changeName">Change Name</button>
  </div>
</template>

<script setup>
import { reactive } from 'vue';

// 创建一个 reactive 对象
const state = reactive({
  name: 'John'
});

const changeName = () => {
  // 直接修改 reactive 对象的属性
  state.name = 'Jane';
};
</script>

三、适用场景

1. ref

  • 基本数据类型 :当需要对基本数据类型(如数字、字符串、布尔值)进行响应式处理时,ref 是首选。因为基本数据类型没有属性,无法直接使用 reactive
  • 在模板中使用 :在模板中使用 ref 时,Vue 会自动解包 .value,使得使用起来更加方便。
  • 跨组件传递ref 可以方便地在组件之间传递,接收方可以通过 .value 访问和修改其值。
  • 复杂对象 :虽然 ref 可用于复杂对象,但使用时要注意通过 .value 来操作对象。当传入对象时,ref 会借助 reactive 让对象具有响应式能力。

2. reactive

  • 对象和数组 :当需要对对象或数组进行响应式处理时,reactive 更加合适。它可以递归地将对象的所有属性转换为响应式的。
  • 复杂数据结构 :对于包含多个属性的复杂对象,使用 reactive 可以避免为每个属性创建单独的 ref,且使用时无需 .value 这样的额外操作。

四、内部实现区别

1. ref

ref 内部使用了一个 RefImpl 类来包装传入的值,通过 gettersetter 来实现响应式。当传入对象时,会调用 reactive 方法将对象转换为响应式对象。当访问 ref.value 属性时,会触发 getter,收集依赖;当修改 .value 属性时,会触发 setter,通知依赖更新。

2. reactive

reactive 内部使用了 Proxy 对象来拦截对象的属性访问和修改操作。当访问或修改 reactive 对象的属性时,Proxy 会自动收集依赖或通知依赖更新。

五、注意事项

1. ref 在对象中的使用

ref 作为 reactive 对象的属性时,在访问时会自动解包 .value

vue 复制代码
<script setup>
import { ref, reactive } from 'vue';

const count = ref(0);
const state = reactive({
  count
});

// 这里不需要使用 state.count.value
console.log(state.count); 
</script>

2. 响应式丢失问题

reactive 对象在解构赋值后会失去响应式特性,而 ref 不会。

vue 复制代码
<script setup>
import { reactive } from 'vue';

const state = reactive({
  name: 'John'
});

// 解构赋值后,name 失去响应式
const { name } = state; 
</script>

综上所述,refreactive 各有优缺点,在实际开发中需要根据具体的场景选择合适的工具。

相关推荐
ayqy贾杰10 小时前
Agent First Engineering
前端·vue.js·面试
IT_陈寒10 小时前
SpringBoot实战:5个让你的API性能翻倍的隐藏技巧
前端·人工智能·后端
iceiceiceice10 小时前
iOS PDF阅读器段评实现:如何从 PDFSelection 精准还原一个自然段
前端·人工智能·ios
大金乄11 小时前
封装一个vue2的elementUI 表格组件(包含表格编辑以及多级表头)
前端·javascript
葡萄城技术团队11 小时前
【性能优化篇】面对万行数据也不卡顿?揭秘协同服务器的“片段机制 (Fragments)”
前端
程序员阿峰12 小时前
2026前端必备:TensorFlow.js,浏览器里的AI引擎,不写Python也能玩转智能
前端
Jans12 小时前
Shipfe — Rust 写的前端静态部署工具:一条命令上线 + 零停机 + 可回滚 + 自动清理
前端
徐小夕12 小时前
JitWord 2.3: 墨定,行远
前端·vue.js·github
南果梨12 小时前
OpenClaw 完整教程!从安装到使用(官方脚本版)
前端·git·开源
大雨还洅下12 小时前
前端手写: new操作符
前端