news 2026/5/12 20:09:41

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/11 7:30:36

d3dcompiler_47.dll缺失怎么修复 免费下载文件方法分享

在使用电脑系统时经常会出现丢失找不到某些文件的情况,由于很多常用软件都是采用 Microsoft Visual Studio 编写的,所以这类软件的运行需要依赖微软Visual C运行库,比如像 QQ、迅雷、Adobe 软件等等,如果没有安装VC运行库或者安装…

作者头像 李华
网站建设 2026/4/27 3:13:53

【Django毕设源码分享】基于Python的高校传染病疫情防控信息管理系统(程序+文档+代码讲解+一条龙定制)

博主介绍:✌️码农一枚 ,专注于大学生项目实战开发、讲解和毕业🚢文撰写修改等。全栈领域优质创作者,博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战 ✌️技术范围:&am…

作者头像 李华
网站建设 2026/5/2 19:35:06

【TVM教程】Pass 基础设施

TVM 现已更新到 0.21.0 版本,[TVM 中文文档]已经和新版本对齐。 Apache TVM 是一个深度的深度学习编译框架,适用于 CPU、GPU 和各种机器学习加速芯片。更多 TVM 中文文档可访问 →[Apache TVM] 在线运行 TVM 学习教程 链接是:https://hype…

作者头像 李华