AST介绍和babel插件开发

babel是个js编译器,写babel插件其实就是操作ast。
我们日常项目中使用ast的场景很多,比如eslint, codemods, css parsers, css in js等等,不同的工具的ast解析规则可能稍有区别,这里以babel的规范为主。

ast介绍

ast的定义如下

An abstract syntax tree is a tree representation of source code written in a programming language. Each node of the tree denotes a construct occurring in the source code.

ast的处理包括三个步骤, parse, transform, generate,我们关注点在前两步,具体要操作的是第二步。

image.png

parse

将源码解析成ast分为两步,词法分析和语法分析,以 const a = 5 + 3;为例。

词法分析是将源码字符串拆分成一个个token,我们这里把token简化为

interface Token {
 type: string,
 value: string
} 

我们例子里的结果就是

image.png

语法分析就是将这些token组合成ast

image.png

大概如下

{
    "type": "VariableDeclaration",
    "declarations": [{
        "type": "VariableDeclarator",
 
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值