news 2026/5/1 6:10:04

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/4/26 14:50:13

人工智能应用-机器听觉: 05.基于统计的语音识别

基于模式匹配的方法无法描述发音中的各种变动性。例如,不同人在发一个’a’或同一个人发两次‘a’时,都会存在差异。此外,人在识别声音时不仅需要听清发音,还需要有语言背景,才能理解对方说的话。我们都有这样的经验&a…

作者头像 李华
网站建设 2026/4/19 9:42:16

吉瑞替尼Gilteritinib常见副作用指南:分化综合征与肝毒性的识别处理

吉瑞替尼作为FLT3突变AML的靶向药物,其副作用谱涵盖血液系统、消化系统及神经系统等多器官,其中分化综合征与肝毒性是需重点关注的严重不良反应。基于临床研究数据与权威指南,本文详细解析其识别与处理策略。分化综合征:早期识别与…

作者头像 李华
网站建设 2026/4/30 13:32:24

收藏!小白也能秒懂的AI Agent主流设计模式全解析

这篇文章系统介绍了AI Agent的主流设计模式,包括ReAct、Plan & Execute、ReWOO、LLM Compiler及反思增强类架构。文章分析了各模式的核心原理、优缺点及应用场景,强调ReAct通过"思想-行动-观察"循环实现实时反馈,而其他架构则侧…

作者头像 李华
网站建设 2026/4/30 6:17:39

AI量化模型解析贵金属异动:白银单日波动率超10%的技术驱动与黄金突破5100美元的市场逻辑

摘要:本文通过AI多维度市场分析模型,结合全球地缘局势、宏观经济数据、市场资金流向以及外汇波动等多源数据,分析白银盘中上涨超10%、黄金涨破5100美元并创四十年最大月涨的背后驱动因素及未来走势。 一、市场异动背景:地缘风险与…

作者头像 李华