【前端】【面试】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 各有优缺点,在实际开发中需要根据具体的场景选择合适的工具。

相关推荐
阿猿收手吧!1 小时前
【面试】面试常见的智力题
面试·职场和发展
Anlici2 小时前
还只会express?今儿使用Koa2 实现 Jwt鉴权
前端·koa
zhenryx2 小时前
前端-导出png,jpg,pptx,svg
开发语言·前端·javascript
硕风和炜2 小时前
【LeetCode: 8. 字符串转换整数 (atoi) + 模拟】
java·算法·leetcode·面试·模拟
QBorfy2 小时前
02篇 AI从零开始 - 部署本地大模型 DeepSeek-R1
前端·人工智能·deepseek
QBorfy2 小时前
01篇 AI从零开始 - 基础知识和环境准备
前端·人工智能
头顶秃成一缕光3 小时前
Springboot原理(面试高频)
spring boot·后端·面试
朦胧之3 小时前
React Native 新架构 (一)
前端·react native
牛奶3 小时前
前端视界:图解React
前端·react.js·面试