【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
相关推荐
Kagol1 天前
🎉OpenTiny NEXT-SDK 重磅发布:四步把你的前端应用变成智能应用!
前端·开源·agent
GIS之路1 天前
ArcGIS Pro 中的 notebook 初识
前端
JavaGuide1 天前
7 道 RAG 基础概念知识点/面试题总结
前端·后端
ssshooter1 天前
看完就懂 useSyncExternalStore
前端·javascript·react.js
格砸1 天前
从入门到辞职|从ChatGPT到OpenClaw,跟上智能时代的进化
前端·人工智能·后端
Live000001 天前
在鸿蒙中使用 Repeat 渲染嵌套列表,修改内层列表的一个元素,页面不会更新
前端·javascript·react native
柳杉1 天前
使用Ai从零开发智慧水利态势感知大屏(开源)
前端·javascript·数据可视化
兆子龙1 天前
从高阶函数到 Hooks:React 如何减轻开发者的心智负担(含 Demo + ahooks 推荐)
前端
狗胜1 天前
测试文章 - API抓取
前端