ref 底层到底是怎么变成响应式的?

我给你讲 最底层、最准确、面试必对 的:

ref 底层到底是怎么变成响应式的?

我不讲废话,直接讲源码级原理 ,但用人话讲。


一、一句话终极底层结论(背这个)

ref 底层不是直接用 Proxy!

而是分两种情况:

  1. 基本类型(string/number/boolean)
    → 用 get/set 存取器 实现响应式
  2. 对象/数组类型
    → 自动调用 reactive 转成 Proxy 深度响应式

ref 的本质是一个对象,自带 .value 属性。


二、ref 底层结构(源码简化版)

你写:

js 复制代码
const count = ref(0)
const user = ref({ name: 'zs' })

底层变成:

js 复制代码
class RefImpl {
  constructor(value) {
    this._value = ??? // 关键在这里
    this.__v_isRef = true
  }

  get value() {
    // 收集依赖
    track()
    return this._value
  }

  set value(newVal) {
    this._value = ???
    // 触发更新
    trigger()
  }
}

三、真正的响应式实现(最核心)

1. 当 ref 传入 基本类型

js 复制代码
const count = ref(0)

底层:

  • 不使用 Proxy
  • 直接用 get value() / set value() 监听
  • 修改 count.value → 触发 set → 更新视图

这是基本类型的响应式原理。


2. 当 ref 传入 对象/数组

js 复制代码
const user = ref({ name: 'zs' })

底层:

  • 自动调用 reactive()
  • 把对象变成 Proxy 深度响应式
  • 所以 user.value.name 能响应式
js 复制代码
this._value = reactive(value)

也就是说:对象 ref = reactive 套了一层 .value


四、一张图看懂 ref 底层

复制代码
ref(基本类型)
   → get/set 监听 .value → 响应式

ref(对象/数组)
   → 自动转 reactive → Proxy → 深度响应式

五、超级重点结论(面试 100% 问)

  1. ref 基本类型 = 存取器(get/set)实现响应式
  2. ref 对象类型 = 自动调用 reactive = Proxy 响应式
  3. ref 一定有 .value,因为它是对象包装
  4. ref 是完整响应式,不是浅响应

六、面试标准答案(背这个)

问:Vue3 ref 底层是如何实现响应式的?

答:
ref 底层是一个 RefImpl 类,通过 .value 的 get/set 存取器实现响应式。
如果传入基本类型,直接监听 .value;
如果传入对象,会自动调用 reactive 并转为 Proxy 深度响应式。


相关推荐
行者全栈架构师13 小时前
UniApp集成vk-uview-ui组件库详解:打造高效UI开发体验
前端·vue.js
Csvn15 小时前
Vue 3 defineModel 翻车实录:多个 v-model 绑定到底怎么写?
前端·vue.js
Momo__17 小时前
VueUse createReusableTemplate —— 单文件组件内的模板复用神器
前端·vue.js
程序员小富17 小时前
我开源了一个开发者专属的智能 JSON 工具,得到了媳妇高度认可
前端·vue.js·后端
JustHappy18 小时前
「软件设计思想杂谈🤔」“切图仔”也能懂编译原理?框架源码也许没那么难。聊聊 Vue 的编译(上)
前端·javascript·vue.js
假如让我当三天老蒯2 天前
Options API(选项式 API) 和 Composition API(组合式 API)
前端·vue.js·面试
秃头网友小李5 天前
前端难点:keep-alive 缓存什么?RouterView 的 key 为什么要带 scopeId?
前端·vue.js
徐小夕5 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法
奋斗吧程序媛5 天前
补充一个小知识点:有关@click.native
前端·vue.js
英勇无比的消炎药5 天前
一行命令背后:TinyRobot CLI 如何重构 AI 对话接入的效率范式
vue.js·aigc