说说Vue 模板是如何编译的?

Vue 的模板编译是 Vue 框架中的一个核心机制,它把我们写的模板(如 <template> 中的 HTML 结构)转换成高效的 JavaScript 渲染函数,最终生成真实的 DOM 或虚拟 DOM。

整体流程概览 🧩

graph LR 模板字符串 --> 解析器Parser --> AST抽象语法树 --> 优化器Optimizer --> 优化后的AST标记静态节点 --> 代码生成器Codegen --> render函数 --> 运行时执行 --> 生成Virtual_DOM --> 更新真实DOM

详细步骤拆解 🔍

解析阶段(Parser)

  • 把模板字符串 <template>...</template> 转换为抽象语法树(AST)。
  • AST 是一个用来描述模板结构的 JSON 对象,记录每个标签、属性、插值表达式等信息。

例如:

html 复制代码
<template>
  <div class="hello">{{ msg }}</div>
</template>

对应 AST 节点(简化):

json 复制代码
{
  "tag": "div",
  "attrs": [{ "name": "class", "value": "hello" }],
  "children": [
    { "type": "Interpolation", "content": "msg" }
  ]
}

优化阶段(Optimizer)

  • 作用:标记模板中哪些是静态节点,不需要每次更新时都重新生成。
  • 好处:极大提升性能,避免不必要的 diff。

代码生成阶段(Codegen)

  • 将 AST 转换为 JavaScript 的 render 函数:
js 复制代码
function render(ctx) {
  return h("div", { class: "hello" }, ctx.msg)
}

这个函数就是运行时执行生成虚拟 DOM 的关键

运行时阶段(执行 render 函数)🚀

  • Vue 会执行上一步生成的 render 函数,得到虚拟 DOM(VNode)。
  • 最后通过 patch 算法把虚拟 DOM 渲染/更新成真实 DOM。

Vue2 vs Vue3 编译机制差异 🧠

区别 Vue 2 Vue 3
编译方式 运行时模板编译 or 预编译 推荐预编译(更快)
虚拟 DOM 手写实现 重构成 Proxy + Block Tree
优化逻辑 静态标记不够彻底 更强的静态提升和 patch 优化
模板入口 Vue.compile @vue/compiler-dom 提供完整编译链

补充:你可以手动查看模板是如何编译的 🔬

方法一:使用官方在线编译工具

👉 地址:template-explorer.vuejs.org/

粘贴一段模板,它会展示:

  • AST 抽象语法树
  • 生成的 render 函数
  • Vue3 block tree 等优化结果

总结记忆 🔚

阶段 作用
模板解析 生成 AST
静态优化 标记静态节点
渲染函数生成 转为 render 函数
虚拟 DOM 创建 render 执行得到 VNode
DOM 更新 patch 虚拟 DOM 到真实 DOM

如果想深入了解 Vue3 的编译器源码,可以从 @vue/compiler-core 包入手,里面包含了完整的解析、优化、生成等核心模块。

模块 说明
@vue/compiler-core 编译器核心逻辑(解析、优化、代码生成)
@vue/compiler-dom 面向浏览器的模板编译器(使用 compiler-core)
@vue/compiler-sfc 处理 .vue 单文件组件
@vue/compiler-ssr SSR 渲染使用的编译器

推荐前置知识:

  • 熟悉 Vue3 的模板语法(包括指令、插值、条件、循环等)
  • 熟悉 AST(抽象语法树)的结构和基本操作
  • 熟悉 JavaScript 的递归与字符串处理
  • 理解虚拟 DOM 与渲染函数的基本原理
相关推荐
weisian1516 分钟前
基础篇--概念原理-2-参数是什么?——从原理到实战,一篇讲透
面试·职场和发展·模型参数·7b和70b·参数=规则,不是原始数据
AI人工智能+电脑小能手1 小时前
【大白话说Java面试题】【Java基础篇】第26题:Java的抽象类和接口有哪些区别
java·开发语言·面试
Python私教3 小时前
Pure-Admin-Thin 深度解析:完整版和精简版到底怎么选?
vue.js·人工智能·开源
逻辑驱动的ken4 小时前
Java高频面试考点场景题20
java·开发语言·深度学习·面试·职场和发展
Wect4 小时前
深度剖析浏览器跨域问题
前端·面试·浏览器
刀法如飞6 小时前
Java数组去重的20种实现方式——指导AI解决不同问题的思路
java·算法·面试
ayqy贾杰6 小时前
Cursor SDK发布!开发者可直接搬走其内核
前端·vue.js·面试
李白的天不白6 小时前
vue 数据格式问题
前端·vue.js·windows
小白蒋博客6 小时前
【ai开发段永平投资理财的知识图谱网站】第一天:搭 Vite + Vue 项目,跑通 Hello World
vue.js·人工智能·trae
JAVA面经实录91715 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试