美文网首页
AST与babel

AST与babel

作者: 习惯水文的前端苏 | 来源:发表于2022-04-10 15:29 被阅读0次

AST


\bullet 什么是ast

    ast又称抽象语法树,以树形结构描述代码,一般是json对象。与ast相关的操作通常有三步:\alpha 解析、\beta 遍历、\gamma 生成代码

    在前端领域,个人认为最为nb的应用当属尤大实现的模板解析器了,通过对template遍历解析,匹配标签上的字符并转换为对应的vue语法,最终在遍历进行codegen

\bullet 生成流程

    \alpha 扫描(scanner)源码

    \beta 进行词法分析,生成token流

        可见词法分析其实就是提取关键字的过程,对于分号、换行、注释等是直接忽略的

    \gamma 对tokens进行语法解析(parser),生成(transform)ast

            可见其将tokens流转换成了具有特殊语义的json描述,这里缺少了关键信息在代码字符的源位置标识,正常来说是应该有这部分信息的

    \delta 遍历生成代码

        生成代码的过程是整个ast应用的切入点,允许在该过程对代码进行修改,如babel的插件机制等


BABEL


\bullet 工程配置

    \ast npm init -y 初始化package,json

    \ast npm install --save-dev @babel/core @babel/cli @babel/preset-env  

        \alpha core是bable提供的用于ast操作的核心模块,如parser、traverse、generator、types等

            parse用于将源代码转换为ast树

            traverse提供了对ast的修改接口

            generate用于生成转换后的代码

            types则提供了一整套节点类型的判断和创建方法

        \beta cli是babel提供的脚手架工具

        \gamma preset-env是babel官方预设的配置

    \ast 新建babel.config.json配置文件

    \ast scripts增加build指令

    \ast 测试

\bullet npm run build编译流程

    \ast 引入依赖,准备字符串代码

    \ast 生成ast

    \ast 遍历ast,为函数添加console.log(运行插件)

    \ast 生成code

工具与文档


\bullet 代码工具

    recast \vert  exprima \vert  babylon

\bullet 在线工具

    ast在线分析 \vert  tokens在线分析

\bullet 文档

    js中的ast节点类型 \vert  babel中的节点函数 \vert  babel文件配置 \vert  babel插件手册


相关文章

  • AST、Babel、依赖

    babel 与 AST 先从Babel 说起 babel 的原理1、parse:把代码 code 变成 AST2、...

  • babel插件入门-AST

    目录 Babel简介 Babel运行原理 AST解析 AST转换 写一个Babel插件 Babel简介 Babel...

  • 一个bebel插件

    Babel它的原理,简单点说: Babel解析成AST,然后插件更改AST,最后由Babel输出代码

  • babel 与 AST

    babel原理 parse把代码code 变成 ast traverse 遍历ast 进行修改 generate ...

  • AST与babel

    AST 什么是ast ast又称抽象语法树,以树形结构描述代码,一般是json对象。与ast相关的操作通常有三...

  • 【Webpack】AST、babel、依赖

    babel babel的原理 1、parse:把代码变成AST2、traverse:遍历AST进行修改;3、gen...

  • vue3原理

    AST AST:抽象语法树,Abstract Syntax Tree。TypeScript、babel、webpa...

  • AST、Babel、依赖

    Babel babel 的原理 parse: 把代码 code 变成 ASTtraverse: 遍历 AST 进行...

  • babel 核心

    1.babel/core babel/core的作用 = babel/parser(词法分析+语法分析 = AST...

  • 深入webpack之babel 与 AST

    babel的原理 parse:把代码code变成AST traverse:遍历AST进行修改 generate:把...

网友评论

      本文标题:AST与babel

      本文链接:https://www.haomeiwen.com/subject/yerdsrtx.html