【vue高频面试题】第2题:Vue 3 中 ref 和 reactive 的区别是什么?什么时候用哪一个?

Vue 3 中 refreactive 使用指南(面试/实战)

主问题

问:refreactive 的区别是什么?什么时候用哪一个?

面试官追问(示例)

  • 基础区别:底层实现差异?reactive 包基本类型会怎样?
  • 使用场景:哪些场景必须用 ref?何时更适合 reactive
  • 模板绑定:为何模板里 ref 不需要 .valuereactive 是否需要?
  • 响应式嵌套:嵌套对象是否响应?深层嵌套如何优化?

参考答案 / 要点整理

1. 基础区别

特性 ref reactive
数据类型 基本类型或对象 对象或数组
返回值 包装对象 { value: ... } 直接返回代理对象(Proxy)
模板访问 模板自动解包,无需 .value 直接使用属性
底层实现 RefImpl + Proxy(访问时解包) Proxy 深度响应式

示例:

ts 复制代码
import { ref, reactive } from 'vue';

const count = ref(0);              // 基本类型 → 使用 ref
const state = reactive({ a: 1 });  // 对象/数组 → 使用 reactive

2. 使用场景

  • 选择 ref
    • 基本类型(stringnumberboolean)。
    • 需要单独引用/独立更新的值(计数器、输入值)。
  • 选择 reactive
    • 管理对象/数组的整体状态(包含多属性)。
    • 深层嵌套对象需整体响应式代理。

3. 模板绑定与 .value

<template> 中,Vue 会自动解包 ref,无需 .value。在 JS 逻辑(script)中仍需通过 .value 访问。

vue 复制代码
<template>
  <div>{{ count }}</div>   <!-- 自动解包,无需 .value -->
  <div>{{ state.a }}</div> <!-- reactive 直接访问属性 -->
  
</template>

<script setup lang="ts">
import { ref, reactive } from 'vue'
const count = ref(0)
const state = reactive({ a: 1 })
</script>

4. 响应式嵌套与优化策略

  • reactive 对嵌套对象默认递归响应式,无需手动处理。
  • 对象很大或深层嵌套场景,可拆分为多个 ref,降低单个 Proxy 的更新成本。
ts 复制代码
import { ref, reactive } from 'vue'

// 整体管理(默认深度响应式)
const user = reactive({
  profile: { name: 'Alice', age: 18 },
  settings: { theme: 'dark' }
})

// 性能敏感场景:拆分为多个 ref,按需更新
const profile = ref({ name: 'Alice', age: 18 })
const settings = ref({ theme: 'dark' })

小结(面试亮点)

  • 基本类型与独立值用 ref,对象/数组用 reactive
  • 模板自动解包 ref;JS 中访问 ref.value
  • 深层嵌套对象可用 reactive;性能敏感场景可拆分为多个 ref
相关推荐
donecoding31 分钟前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马35 分钟前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren39 分钟前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川41 分钟前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
许彰午1 小时前
我手写了一个 Java 内存数据库(二):B+ 树的插入与分裂
java·开发语言·面试
jinanwuhuaguo1 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技1 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
Alice-YUE2 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀3 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记