news 2026/4/3 5:28:10

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/3/15 13:58:41

聊聊整车试验那些事儿

整车系统试验项目清单,整车试验项目清单,整车DVP模型和系统DVP模型,包含整车、系统及零部件,并给出了试验项目开展阶段。 在汽车研发的复杂版图中,整车系统试验项目清单以及相关的DVP(Design Verification…

作者头像 李华
网站建设 2026/3/20 12:32:48

开题报告 网上水果销售系统

目录网上水果销售系统概述核心功能模块技术实现要点行业趋势与优势项目技术支持可定制开发之功能亮点源码获取详细视频演示 :文章底部获取博主联系方式!同行可合作网上水果销售系统概述 网上水果销售系统是基于电子商务平台的水果零售解决方案&#xff…

作者头像 李华
网站建设 2026/4/2 15:36:46

【dz-693】基于单片机的智能家居控制系统设计

摘要 传统智能家居控制手段往往存在自动化程度低、控制方式单一、各设备协同性差等问题,难以满足现代用户对家居环境便捷化、智能化控制的需求。​ 基于 STM32F103C8T6 单片机的智能家居控制系统,整合了 DS1302 时钟模块、光照检测模块 5526、人体热释…

作者头像 李华
网站建设 2026/4/3 5:01:19

Moto 隐藏黑科技!“敲敲后背” 便捷操作,解锁手机使用新姿势

用惯了触屏点击、滑动操作,总觉得手机还能有更灵活的交互方式?尤其是双手持握手机时,想快速打开相机、调取健康码,或是暂停音乐,频繁滑动屏幕不仅麻烦,还容易误触。而 Moto 系列手机藏着一个超实用的便捷功…

作者头像 李华
网站建设 2026/3/22 23:17:11

金现代:主动调结构加速发展标准化产品,经营现金流大幅增长

1月30日晚间,金现代(300830.SZ)发布2025年业绩预告及计提资产减值准备公告。预计2025年归属于上市公司股东的净利润预计为-9,000万元至-7,000万元,较上年同期1,152.61万元由盈转亏;扣除非经常性损益后的净利润预计为-1…

作者头像 李华