news 2026/6/10 19:06:28

Vue-实例从 createApp 到真实 DOM 的挂载全历程

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Vue-实例从 createApp 到真实 DOM 的挂载全历程

前言
无论是 Vue 2 的new Vue()还是 Vue 3 的createApp(),将组件配置转化为页面上可见的真实 DOM,中间经历了一系列复杂的转换。理解这一过程,不仅能帮我们更好地掌握生命周期,更是理解响应式原理的基础。
一、 挂载过程总览
Vue 实例的挂载过程,本质上是将组件配置转化为虚拟 DOM,最终映射为真实 DOM,并建立响应式双向绑定的过程。


二、 核心挂载步骤详解
1. 初始化阶段 (Initialization)
在 Vue 3 中,通过createApp开始。

  • 创建实例:根据传入的根组件配置创建一个应用上下文(vue实例),接着进行数据初始化。
  • 初始化数据:这是最关键的一步。Vue 会依次初始化Props、Methods、Setup (Vue 3)、Mixins、Data、Computed
    • 校验:Vue 会校验propsdata中的变量名是否重复。
    • 响应式绑定:Vue 3 使用Proxy(Vue 2 使用Object.defineProperty)对数据进行劫持,建立依赖收集机制。

2. 模板编译阶段 (Template Compile)
这一步将“肉眼可见”的 HTML 模板转化为机器高效执行的 JavaScript 代码。

  • 解析 (Parser):将template字符串解析为抽象语法树 (AST)
  • 转换 (Transformer):对 AST 进行静态提升、补丁标记(Patch Flags)等优化。
  • 生成 (Generator):将 AST 转换成render 渲染函数字符串。

3. 生成虚拟 DOM (VNode)

  • Vue 调用生成的render函数。
  • render函数根据Template执行后会返回一个虚拟 DOM 树 (Virtual DOM)。它是对真实 DOM 的一种轻量级 JavaScript 对象描述。

4. 挂载与 Patch (Mounting & Patching)

  • 调用 Mount:执行组件的挂载方法。
  • 渲染真实 DOM:渲染器(Renderer)遍历虚拟 DOM 树,递归创建真实的 HTML 元素。
  • 更新页面:将生成的真实 DOM 插入到指定的容器(如#app)中,替换掉原本的内容。

5. 完成挂载

  • 一旦真实 DOM 渲染完毕,Vue 会触发mounted(组合式 API 为onMounted)生命周期钩子,此时开发者可以安全地访问 DOM 节点。

三、 Vue 3 挂载示例
在 Vue 3 项目中,挂载通常发生在main.ts
// main.ts import { createApp } from 'vue' import App from './App.vue' // 1. 创建应用实例 const app = createApp(App) // 2. 挂载到指定 DOM 容器 // 挂载过程中会执行编译、数据拦截、生成 VNode 并渲染 app.mount('#app')


四、 总结

  1. AST 与 VNode 的区别
  • AST:是对 HTML 语法的描述,用于代码编译阶段。
  • VNode:是对 DOM 节点的描述,用于运行时渲染和 Diff 算法。
  1. 双向绑定的建立时机:在data初始化阶段,Vue 就已经通过响应式 API 拦截了数据。当render函数读取数据时,会自动触发依赖收集。
  2. 重新挂载:如果响应式数据发生变化,Vue 不会重新走一遍完整的挂载过程,而是通过Diff 算法对比新旧 VNode,仅更新发生变化的真实 DOM 部分。



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

多品牌、多品类如何高效协同?国产PLM如何统一日化研发标准与流程

引言:日化行业进入协同内卷时代,研发标准化成破局关键 随着消费需求的多元化升级,日化行业已从“单一品牌单品突围”迈入“多品牌、多品类协同发展”的新阶段,护肤、彩妆、家清、个护等品类交叉布局,多品牌矩阵成为头…

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

【dz-700】基于STM32智能水族箱的设计

摘要 在水族饲养日益普及的当下,水族箱环境的精准调控对保障水生生物的健康生长至关重要。传统的水族箱管理依赖人工操作,存在监测不及时、调控精度低、劳动强度大等问题,难以满足现代化、精细化饲养的需求。​ 基于 STM32F103C9T6 单片机的…

作者头像 李华
网站建设 2026/6/8 16:10:41

云服务器:从技术革新到产业重构的进化之路​​

如果说互联网是数字时代的高速公路,那么云服务器就是支撑这条公路高效运转的核心枢纽。从早期单一的物理服务器托管,到如今融合云计算、大数据、人工智能的综合服务平台,云服务器的进化史,正是数字经济重构产业格局的缩影。它不仅…

作者头像 李华
网站建设 2026/6/10 19:05:35

云服务器深度解析:技术内核、应用场景与上云避坑指南​

在数字时代,云服务器早已不是抽象的技术概念,而是支撑个人数字生活、企业业务运转的核心基础设施。但多数人只知其 “好用”,却不懂其 “为何好用”;企业急于上云,却常陷入选型误区。本文将从技术内核、场景适配、避坑…

作者头像 李华