2023-07-12 23:25:04 +08:00
..
2023-07-12 23:25:04 +08:00
2023-07-12 23:25:04 +08:00

ast 构建过程

源码--》词法分析--》生成词法数组--》语法parser--》ast树

浏览器会把源码转换成ast树再转换成字节码

debugger

ast 构建细节

遍历源码进行分词算法生成tokens数组,再遍历tokens数组进行语法解析最终生成ast树顶层是一个Program程序, start代码开始位置end是代码结束位置body是具体代码内容。

debugger

主要的代码映射关系Identifier标识符是a,init初始化为1

{
  "type": "VariableDeclaration",
  "start": 0,
  "end": 10,
  "declarations": [
    {
      "type": "VariableDeclarator",
      "start": 4,
      "end": 9,
      "id": {
        "type": "Identifier",
        "start": 4,
        "end": 5,
        "name": "a"
      },
      "init": {
        "type": "Literal",
        "start": 8,
        "end": 9,
        "value": 1,
        "raw": "1"
      }
    }
  ],
  "kind": "var"
}

为什么要分词生成tokens数组

debugger

babel 核心模块

debugger

理解path和node

path就是路径node就是节点找到某个node节点必须通过path所有node节点都是绝对路径

debugger

path api

node可以通过path上api进行操作的

debugger