Vue template到render过程,以及render的调用时机

Vue template到render过程

vue的模版编译过程主要如下:template -> ast -> render函数

vue 在模版编译版本的码中会执行 compileToFunctions 将template转化为render函数:

javascript 复制代码
// 将模板编译为render函数
const { render, staticRenderFns } = compileToFunctions(template,options, this)

CompileToFunctions中的主要逻辑如下∶

(1)调用parse方法将template转化为ast(抽象语法树)

javascript 复制代码
constast = parse(template.trim(), options)

parse的目标:把tamplate转换为AST树,它是一种用 JavaScript对象的形式来描述整个模板。

解析过程:利用正则表达式顺序解析模板,当解析到开始标签、闭合标签、文本的时候都会分别执行对应的 回调函数,来达到构造AST树的目的。

AST元素节点总共三种类型:type为1表示普通元素、2为表达式、3为纯文本

(2)对静态节点做优化

javascript 复制代码
optimize(ast,options)

这个过程主要分析出哪些是静态节点,给其打一个标记,为后续更新渲染可以直接跳过静态节点做优化

深度遍历AST,查看每个子树的节点元素是否为静态节点或者静态节点根。如果为静态节点,他们生成的DOM永远不会改变,这对运行时模板更新起到了极大的优化作用。

(3)生成代码

javascript 复制代码
const code = generate(ast, options)

generate将ast抽象语法树编译成 render字符串并将静态部分放到 staticRenderFns 中,最后通过 new Function("render") 生成render函数。

render函数的调用时机

在beforeMount生命周期钩子期间调用,因为此时,模板编译已完成,但是为渲染成真实DOM

相关推荐
米兰小铁匠178 分钟前
js深入之从原型到原型链
javascript·面试
Smile_Gently18 分钟前
Vue 2 前端项目实现 在线IDE 功能
javascript
梦鱼19 分钟前
element-ui:el-autocomplete实现滚动触底翻页
前端
阿伟实验室23 分钟前
debian10部署简易web服务器
运维·服务器·前端
云枫晖31 分钟前
Vue3 响应式原理:从零实现 Reactive
前端·vue.js
月弦笙音31 分钟前
【AI】👉提示词入门基础篇指南
前端·后端·aigc
jason_yang32 分钟前
俄罗斯Yandex地图实战
vue.js·api
konh38 分钟前
React Native 自定义字体导致 Text / TextInput 文本垂直不居中的终极解决方案
前端·react native
奔赴_向往38 分钟前
跨域问题深度剖析:为何CORS设置了还是报错?
前端
daols881 小时前
vxe-table 配置 ajax 加载列表数据,配置分页和查询搜索表单
vue.js·ajax·table·vxe-table