学习
实践
活动
专区
工具
TVP
写文章

AST 介绍

AST是编译器看的。编译器会将源码转化成ASTAST 的使用场景? TypeScript、babel、webpack、vue-cli 得都是依赖 AST 进行开发的。 通过AST,可以将代码转化后,再输出。比如: 代码压缩。 修改路由配置需要通过AST来转换代码。 需要学习 AST 的哪些知识? 0 了解AST常见节点的结构 了解AST常见节点的结构推荐通读下AST node 规范。 1 源码解析 将源码转化为AST。 2 转换 在遍历AST时,对指定的AST节点做新增,修改或删除操作。 转换可以用@babel/traverse。 创建和验证节点可以用@babel/types。创建AST节点代码示例见这里。 生成目标代码可以用@babel/generator 工具 AST 浏览器 AST 可视化工具 npm 包 recast AST工具库。解析AST(parse),遍历AST,修改AST,生成代码。

1.3K10
  • 广告
    关闭

    有奖征文丨玩转 Cloud Studio

  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    AST in TypeScript 实践

    回到 AST 的话题中,因为 TypeScript 在近几年才算热门,AST 在 TypeScript 的应用上的优秀实践也难得一见,相关的文档及教程也不算太完整,于是开始了 AST in TypeScript [ AST ]   在 AST Explorer 中,我们甚至查看生成的 JSON 格式的解析结果。   在解析后得到 AST 后,下一步我们就需要开始分析它的结构了。 babel/traverse 这个工具,进行对 AST 快速的节点遍历与筛选。 通过 babel/types 的 API ,我们可以很方便的构造出对应的 AST 语法块,而后加入到 AST 中。 @babel/generator   最后,我们已经完成对 AST 的查找,更改,插入操作了,下一步就是把 AST 转换成 JavaScript 代码了,这时候我们就会用到 babel/generator

    4.2K430

    AST是什么?

    AST是什么? 在计算机科学中,抽象语法树(Abstract Syntax Tree,AST),或简称语法树(Syntax tree),是源代码语法结构的一种抽象表示。 一般的,在源代码的翻译和编译过程中,语法分析器创建出分析树,然后从分析树生成AST。一旦AST被创建出来,在后续的处理过程中,比如语义分析阶段,会添加一些信息。 ---维基百科 最后 在一些开源或者商业的规则引擎中就是存在各种种样的一些AST,比如:Drools,还有的话在现代的react或vue底层就是通过AST来进行建设的,这块有兴趣的同学可以去了解一下 至于个人的理解:最接地气的说明抽象语法树,也可统称流程的规类,然后分解为各种动作或指令,当然这些是自定义,核心还是分析和解决问题,比如像前端的或一些引擎就将AST加入解析器和过滤器,那么解析器里面又有解析

    21430

    Cobar源码分析之AST

    from type_config where status = 0) 经过Cobar SQL Parser后,生成了如下AST对象: [img2.png] 这个AST的根节点就是select语句,然后每个属性都是叶子节点 AST操作 有了如上对AST的了解,接下来看对AST的操作,最基本的是遍历,利用ASTNode的accept,需要实现SQLASTVisitor接口,这个SQLASTVisitor定义如下: [img4 比如MySQLOutputASTVisitor可以遍历AST,将AST还原为SQL输出,只需要这样: SQLStatement stmt = SQLParserDelegate.parse(sql); AST的应用 分库分表 Cobar中利用AST可以获取table名、列名、比较的值进行分库分表,这也是Cobar最重要的功能。 最后 本文从SQL AST的来源、结构、遍历原理、应用等方面进行介绍,相信看完文章会对SQL AST有了初步的了解,如果想进一步了解可以参考Cobar项目中的单元测试进行实际的演示感受。

    39411

    AST 与前端工程化实战AST 与前端工程化实战

    AST 是一个非常基础但是同时非常重要的知识点,我们熟知的 TypeScript、babel、webpack、vue-cli 都是依赖 AST 进行开发的。 本文将通过 AST 与前端工程化的实战向大家展示 AST 的强大以及重要性。 直播分享视频地址:AST 与前端工程化实战 一、初识 AST 1、demo-1 第一次看见 AST 这个概念的时候还是在《你不知道的 JavaScript》一书中看到的。 开始之前,先给大家推荐一个在线查看 AST 结构的平台,非常好用 AST Explorer 相信对 babel 稍有了解的同学都知道,babel 有一系列包对 AST 进行了封装,专门来处理编译这块的事宜 最后,希望文章的内容能够帮助小伙伴了解到:什么是 AST?如何借助 AST 让我们的工作更加效率?AST 又能为前端工程化做些什么?

    80740

    漫谈NAT(一):各种NAT类型

    之后出现ePort的地方都可默认为(eAddr, ePort)。 发送时,通过(iAddr, iPort)查出(ePort)。如果查不到相关记录,则分配一个ePort并记录到NAT表。 接收时,通过(ePort)查出(iAddr, iPort) 可以发现,全锥体NAT下一个外部IP上的端口ePort,会被唯一分给一个内网设备的端口iAddr:iPort。 )查出(ePort) 接收时,通过(ePort, dAddr, dPort)查出(iAddr, iPort) 可以发现,它比地址受限型NAT还要多查找了一个dPort。 端口分配发生在第一次映射行为时,用来产生映射的目标端口ePort。 端口保留(port preservation):NAT将尽可能保证ePort == iPort。 比如在映射时替换掉之前拿到ePort的内部端口,或者维护一个地址池,分配不同外部地址的ePort端口eAddr:ePort

    1.3K10

    使用 AST 实现 babel 插件编写

    使用 AST 实现 babel 插件编写1. AST介绍webpack 和 Lint 等很多库是通过 AST 抽象语法树来实现的。 AST常用于代码语法检查、⻛格检查、格式化、代码提示、混淆压缩、自动补全等,还可以用来优化代码结构,如 webpack 以及 CommonJS、AMD、CMD、UMD等代码规范之间的转化等。 使用 esprima 做 js 代码转换目标:将下面代码转换成AST,将ast函数转换成新的函数newAstfunction ast(){}js代码的语法转换涉及到3个npm包:esprima:JS词法 、语法分析工具,支持转换代码为 ASTestraverse:AST遍历和更新工具escodegen:AST重新生成源码首先安装这3个包:$ npm i esprima estraverse escodegen = require('escodegen');let code = `function ast(){}`;// 将代码转换成ast语法树const ast = esprima.parseScript(

    804441

    扫码关注腾讯云开发者

    领取腾讯云代金券