【vue】vue 是怎么把 template 模版编译成 render 函数的,什么是AST抽象语法树

news/发布时间2024/6/16 22:04:34

什么是AST 抽象语法树

  1. 是一个对象/或者json
  2. 是一个数据结构
  3. AST通常是由多个节点组成的树状结构,每个节点代表一个语法单位或表达式。节点之间的关系通过父子关系或兄弟关系来表示程序的结构。在不同的编程语言和工具中,AST可能有不同的表示方式和节点类型。

  4. const ast = {type: "Program",body: [{type: "FunctionDeclaration",id: {type: "Identifier",name: "add"},params: [{type: "Identifier",name: "a"},{type: "Identifier",name: "b"}],body: {type: "BlockStatement",body: [{type: "ReturnStatement",argument: {type: "BinaryExpression",operator: "+",left: {type: "Identifier",name: "a"},right: {type: "Identifier",name: "b"}}}]}},{type: "VariableDeclaration",declarations: [{type: "VariableDeclarator",id: {type: "Identifier",name: "result"},init: {type: "CallExpression",callee: {type: "Identifier",name: "add"},arguments: [{type: "Literal",value: 2},{type: "Literal",value: 3}]}}],kind: "let"},{type: "ExpressionStatement",expression: {type: "CallExpression",callee: {type: "MemberExpression",object: {type: "Identifier",name: "console"},property: {type: "Identifier",name: "log"},computed: false},arguments: [{type: "Identifier",name: "result"}]}}],sourceType: "script"
    };console.log(ast);
    

抽象语法树(Abstract Syntax Tree,AST)是源代码的抽象语法结构的树状表示形式。它是编译器、解释器等程序中常用的一种数据结构,用于表示编程语言的语法结构,方便进行语法分析、语义分析以及代码转换等操作。

在编译器的工作流程中,源代码首先会被分词器(Tokenizer)或词法分析器(Lexer)处理,将代码分割成一个个的词法单元(Tokens)。接着,这些词法单元会被传递给语法分析器(Parser),语法分析器会根据语言的语法规则将这些词法单元组织成一个树状结构,这个结构就是抽象语法树。

抽象语法树的节点代表了源代码中的语法结构,例如表达式、语句、函数定义等。每个节点通常包含以下信息:

  1. 类型(Type):节点表示的语法结构的类型,例如表达式、函数声明等。
  2. 值(Value):节点对应的词法单元的值,例如变量名、操作符等。
  3. 子节点(Children):子节点表示了当前节点的子结构,它们可以是其他节点,这样就形成了树的分支。

通过遍历抽象语法树,编译器可以进行诸如优化、转换、生成目标代码等操作。在 JavaScript 生态系统中,许多工具(如 Babel、ESLint 等)都会使用 AST 来进行代码转换、静态分析等操作。在编程语言的学习和理解过程中,理解抽象语法树有助于深入理解语言的语法和结构。

vue 是怎么把 template 模版编译成 render 函数的

  1. 模板解析(Parsing):Vue 会先将模板字符串解析成抽象语法树(AST),这个过程由模板编译器完成。AST 是对模板结构的抽象表示,它描述了模板中各个元素的类型、属性、子节点等信息。

  2. 静态分析(Static Analysis):Vue 会对 AST 进行静态分析,识别出模板中的静态节点(Static Node)和动态节点(Dynamic Node)。静态节点是在编译阶段就可以确定其内容的节点,而动态节点的内容是在运行时确定的,比如包含变量或表达式的节点。

  3. 优化(Optimization):Vue 会对 AST 进行优化,主要是优化静态节点的生成和更新,以提升渲染性能。Vue 3 中引入了基于静态分析的优化策略,可以进一步提高渲染性能。

  4. 代码生成(Code Generation):根据优化后的 AST,Vue 将生成渲染函数的代码。这个过程会根据模板的结构和内容,生成一段 JavaScript 代码,这段代码负责将组件的数据状态映射到 DOM 元素上,并处理组件的更新和交互逻辑。

  5. 缓存(Caching):Vue 会对生成的渲染函数进行缓存,以提高性能。对于同一个模板,Vue 只会进行一次编译,并将编译结果缓存起来,在下次渲染相同模板时直接使用缓存的渲染函数,避免重复的编译过程。

总的来说,Vue 将模板编译成渲染函数的过程是一个将静态模板转换为动态渲染逻辑的过程,它包括模板解析、静态分析、优化和代码生成等步骤,最终生成一个渲染函数,用于渲染组件并处理组件的更新。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.bcls.cn/VTcF/9507.shtml

如若内容造成侵权/违法违规/事实不符,请联系编程老四网进行投诉反馈email:xxxxxxxx@qq.com,一经查实,立即删除!

相关文章

React Vite 构建工具如何查看代码占用体积

首先安装 Vite 中的 rollup-plugin-visualizer 插件 cnpm install rollup-plugin-visualizer 接着在你的 vite.config.ts 中引入并且使用到 plugins 中 import { visualizer } from "rollup-plugin-visualizer";export default defineConfig({plugins: [react(),vi…

【k8s 访问控制--认证与鉴权】

1、身份认证与权限 前面我们在操作k8s的所有请求都是通过https的方式进行请求,通过REST协议操作我们的k8s接口,所以在k8s中有一套认证和鉴权的资源。 Kubenetes中提供了良好的多租户认证管理机制,如RBAC、ServiceAccount还有各种策路等。通…

最新IE跳转Edge浏览器解决办法(2024.2.29)

最新IE跳转Edge浏览器解决办法(2024.2.29) 1.前言2. 解决方案2.1.创建快捷方式2.2.效果 3. 遗留问题 1.前言 在前几天我发布过一个关于使用卸载补丁从而解决最新的IE跳转Edge浏览器的解决方案。   但是这个方案其实存在一个BUG,例如我昨天重…

【算法 - 动态规划】找零钱问题Ⅲ

在前面的动态规划系列文章中,关于如何对递归进行分析的四种基本模型都介绍完了,再来回顾一下: 从左到右模型 :arr[index ...] 从 index 之前的不用考虑,只考虑后面的该如何选择 。范围尝试模型 :思考 [L ,…

React入门之React_使用es5和es6语法渲染和添加class

React入门 //react的核心库 <script src"https://cdn.jsdelivr.net/npm/react17/umd/react.development.js"></script> //react操作dom的核心库&#xff0c;类似于jquery <script src"https://cdn.jsdelivr.net/npm/react-dom17/umd/react-dom.…

程序媛的mac修炼手册-- 2024如何彻底卸载Python

啊&#xff0c;前段时间因为想尝试chatgpt的API&#xff0c;需要先创建一个python虚拟环境来安装OpenAI Python library. 结果&#xff0c;不出意外的出意外了&#xff0c;安装好OpenAI Python library后&#xff0c;因为身份认证问题&#xff0c;根本就没有获取API key的权限…

Linux:进度条的实现

使用工具的简单介绍&#xff1a; 在创建进度条之前&#xff0c;首先要明白两个工具&#xff0c;fflush 和 \r 。 \r 回车键的功能其实是两个&#xff0c;一个是换行&#xff0c;一个是回车。所谓换行就是将光标从这一行变到下一行中&#xff0c;且是垂直下落&#xff0c…

CCF-A类 实时系统研究顶会RTSS‘24 5月23日截稿!引领技术新风暴!

会议之眼 快讯 第45届RTSS (IEEE Real-Time Systems Symposium)即实时系统研讨会将于 2024 年 12月10日 -13日在英国约克举行&#xff01;RTSS作为实时系统领域的首要盛会&#xff0c;为研究人员和从业人员提供了展示全方位创新的平台&#xff0c;涵盖了理论、设计、分析、实施…

1 数据分析概述与职业操守

1、 EDIT数字化模型 E——exploration探索 &#xff08;是什么&#xff09; 业务运行探索&#xff1a;探索关注企业各项业务的运行状态、各项指标是否合规以及各项业务的具体数据情况等。 指标体系——目标&#xff08;O&#xff09;、策略&#xff08;S&#xff09;、指标&a…

android开发书籍推荐,android面试复习

笼统来说&#xff0c;中年程序员容易被淘汰的原因其实不外乎三点。 1、输出能力已到顶点。这个人奋斗十来年了&#xff0c;依旧碌碌无为&#xff0c;很明显这人的天花板就这样了&#xff0c;说白了&#xff0c;天赋就这样。 2、适应能力越来越差。年纪大&#xff0c;有家庭&…

开工大吉,接单助你!

新年的气息逐渐散去&#xff0c;打工人重返岗位&#xff0c;开启新一年的搬砖&#xff01; 虽说&#xff0c;个个都叫嚷着“这个班是非上不可不可嘛&#xff1f;&#xff01;”但不少人新年的第一条朋友圈却是“开工大吉”。好吧&#xff0c; 在生活和金钱的威逼利诱下&#…

Python:练习:输出int值a占b的百分之几。例如:输入1和4,输出:25%。

案例&#xff1a; 输出int值a占b的百分之几。例如&#xff1a;输入1和4&#xff0c;输出&#xff1a;25%。 思考&#xff1a; 所有的一步步思考&#xff0c;最后综合起来。 首先&#xff0c;确定 输出&#xff0c;那么就用input&#xff0c;而且是int值&#xff0c;所以肯定…

【python】网络爬虫与信息提取--scrapy爬虫框架介绍

一、scrapy爬虫框架介绍 scrapy是一个功能强大的网络爬虫框架&#xff0c;是python非常优秀的第三方库&#xff0c;也是基于python实现网络爬虫的重要技术路线。scrapy不是哟个函数功能库&#xff0c;而是一个爬虫框架。 爬虫框架&#xff1a;是实现爬虫功能的一个软件结构和功…

使用python实现一个SCP小工具

源码地址&#xff1a; ssh_scp 工具截图&#xff1a; 一个简易的scp文件上传下载小工具&#xff0c;用来上传或下载一些小文件。 目前只适用于windows&#xff0c; 使用方法&#xff1a; 前提&#xff1a; 工具同级目录&#xff0c;创建一个ssh_commands.json文件。用来存储配…

挑战杯 基于YOLO实现的口罩佩戴检测 - python opemcv 深度学习

文章目录 0 前言1 课题介绍2 算法原理2.1 算法简介2.2 网络架构 3 关键代码4 数据集4.1 安装4.2 打开4.3 选择yolo标注格式4.4 打标签4.5 保存 5 训练6 实现效果6.1 pyqt实现简单GUI6.3 视频识别效果6.4 摄像头实时识别 7 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xf…

关于双向绑定

文章目录 常见的双向绑定实现原理&#xff1a; 父子组件属性的双向绑定$emit 其他方式组件v-modelvue2vue3 想实现双向绑定是为了避免下面的情况&#xff1a;比如子组件更新数据后&#xff0c;父组件没有对应的更新&#xff0c;造成错误。或者页面比较复杂的时候&#xff0c;遗…

鸿蒙(HarmonyOS)项目方舟框架(ArkUI)之FlowItem容器组件

鸿蒙&#xff08;HarmonyOS&#xff09;项目方舟框架&#xff08;ArkUI&#xff09;之FlowItem容器组件 一、操作环境 操作系统: Windows 10 专业版、IDE:DevEco Studio 3.1、SDK:HarmonyOS 3.1 二、FlowItem组件 子组件 可以包含子组件。 接口 FlowItem() 使用该接口来…

关于网络安全从硬件防火墙防御到软件防御论述

服务器的硬防和软防是指对服务器进行保护和防御的两个层次。硬防主要是通过物理手段来保护服务器的安全&#xff0c;包括服务器的物理安全和硬件设备的安全。软防则是通过软件和配置来保护服务器的安全&#xff0c;包括操作系统的安全配置、网络安全配置、防火墙、入侵检测系统…

9.函数,变量作用域(全局作用域和局部作用域),匿名函数,立即执行函数,逻辑中断,常见值布尔判断

函数 其实学习函数学习的不仅仅是在js中如何声明一个函数如何给函数传参如何引用和调用函数&#xff0c;函数在整个编程领域都是一种思想—抽取和封装的思想 那么啥是抽取和封装的思想呢&#xff1f;-------------------------------------------- 抽取 抽取就是比如拿厨房…

信号系统之滤波器比较

比较 1&#xff1a;模拟与数字滤波器 大多数数字信号源自模拟电子设备。**如果需要对信号进行滤波&#xff0c;是在数字化之前使用模拟滤波器&#xff0c;还是在数字化后使用数字滤波器更好&#xff1f;**将通过两个对比来回答问题。 目标是提供 1 kHz的低通滤波器。模拟端是…
推荐文章