news 2026/6/10 18:31:49

VUE 的基本原理

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
VUE 的基本原理

一、基本原理

当一个 Vue 实例创建时,Vue 会遍历 data 中的属性,用 Object.defineProperty(vue3.0 使用 proxy) 将它们转为 getter/setter,并且在内部追踪相关依赖,在属性被访问和修改时通知变化。每个组件实例都有相应的 watcher 程序实例,它会在组件渲染的过程中把属性记录为依赖,之后当依赖项的 setter 被调用时,会通知 watcher 重新计算,从而致使它关联的组件得以更新。

二、更细致的理解

vue 的基本原理也就是:响应式原理。Vue 的“响应式”简单说就是:数据变了,页面自动更新,不需要你手动操作 DOM。

1. 当 Vue 实例创建时发生了什么?

Vue 会对 data 对象里的所有属性做“劫持”:

  • Vue 2 用Object.defineProperty(简称 defineProperty)
  • Vue 3 用Proxy(性能更好)

这个过程叫数据劫持响应式转换

2. Object.defineProperty 是怎么工作的?(Vue 2)

Vue 遍历 data 对象,对每个属性用 defineProperty 改写成:

  • getter:当你读取这个属性时触发(get)
  • setter:当你修改这个属性时触发(set)
  • // 简化版伪代码,Vue 内部就是这么做的 function defineReactive(obj, key, val) { Object.defineProperty(obj, key, { enumerable: true, // 可枚举 configurable: true, // 可配置 get() { console.log(`读取 ${key}:${val}`); // Dep:依赖收集者 -> 记录“谁”在用这个属性 if (Dep.target) { // Dep.target 是当前 Watcher dep.depend(); // 把 Watcher 加到依赖列表 } return val; }, set(newVal) { if (newVal === val) return; console.log(`修改 ${key}:${val} → ${newVal}`); val = newVal; // 通知更新:派发更新 dep.notify(); // 告诉所有依赖这个属性的 Watcher:“数据变了,快更新!” } }); }
  • 依赖收集:在 get 时,把当前正在渲染的组件(Watcher)记录下来(“谁依赖了我”)。
  • 派发更新:在 set 时,通知所有依赖它的 Watcher:“数据变了,去重新渲染吧”。

3. Watcher 是什么?它怎么工作?

每个组件都有一个对应的Watcher(订阅者):

  • 组件第一次渲染时,会触发所有 data 属性的 get → 收集依赖(Dep 收集 Watcher)。
  • 数据变化时,set 触发 → Dep 通知所有 Watcher → Watcher 重新执行渲染函数 → 更新 DOM。

一句话:Watcher 就是“订阅者”,它订阅了 data 的变化,数据一变,它就重新渲染组件。

4. 依赖收集和派发更新的完整流程(Vue 2)

  1. 组件渲染 → 访问 data 属性 → 触发 get → Dep 收集当前 Watcher(依赖收集)。
  2. 数据修改 → 触发 set → Dep 通知所有 Watcher(派发更新)。
  3. Watcher 收到通知 → 重新执行 render → 生成新 VNode → diff → 更新真实 DOM。

5. 总结一句话

Vue 的响应式核心是通过数据劫持 + 发布订阅模式实现的:Vue 2 用 Object.defineProperty 劫持属性,Vue 3 用 Proxy 劫持对象。在渲染时收集依赖(get 时记录 Watcher),数据变化时派发更新(set 时通知 Watcher 重新渲染),实现‘数据变 → 页面自动更新’。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/5/30 4:47:15

Deepoc具身模型开发板:智能采摘机器人的技术突破与产业实践

在智慧农业快速发展的背景下,传统农业采摘环节面临劳动力短缺、作业效率低、采摘质量不稳定等现实挑战。Deepoc具身模型开发板通过创新的技术架构和产业化路径,为智能采摘机器人提供了核心驱动力,实现了从传统人工采摘向智能化精准作业的重要…

作者头像 李华
网站建设 2026/5/21 18:40:18

VSCode 附加进程调试完整指南

目录 概述附加调试 vs 启动调试配置说明使用方法常见场景调试技巧故障排除 概述 附加进程调试(Attach Debugging)是一种强大的调试技术,允许调试器附加到已经运行的进程上,而不需要从调试器启动程序。这在以下场景特别有用&…

作者头像 李华
网站建设 2026/6/9 0:57:53

索洛模型的核心观点对现代经济增长理论有哪些影响?

罗伯特・索洛提出的新古典增长模型(索洛模型)是现代经济增长理论的奠基性框架,其核心观点彻底颠覆了传统增长理论的认知逻辑,不仅重塑了经济学家对经济增长驱动因素的理解,更催生了后续诸多分支理论的发展,…

作者头像 李华
网站建设 2026/6/10 15:48:00

学长亲荐!MBA开题报告必备TOP10一键生成论文工具深度测评

学长亲荐!MBA开题报告必备TOP10一键生成论文工具深度测评 2026年MBA开题报告写作工具测评:精准筛选,高效助力 MBA学员在撰写开题报告时,常常面临选题方向不明确、文献资料繁杂、格式要求严格等挑战。面对这些痛点,一款…

作者头像 李华