ast基础数据类型-cnblog

请添加图片描述

解析代码树

image-20240702094503510

// 声明一个变量 obj,并赋值一个对象
let obj = {
    // 对象的属性 name,值为字符串 "大猩猩"
    name:"大猩猩",
    // 对象的方法 add,接受两个参数 a 和 b
    add:function (a,b){
        // 返回参数 a 和 b 的和加上1000
        return a+b+1000;
    },
    // 对象的方法 mul,接受两个参数 a 和 b
    mul:function (a,b){
        // 返回参数 a 和 b 的乘积加上2
        return a*b+2;
    },
    // 对象定义结束
};

image-20240702095604371

ast 常见语法类型

变量 VariableDeclaration

image-20240702101016653

对比 ast 语法树和 js 代码,首先注意到的是 VariableDeclaration 在 JavaScript 等编程语言中指的是变量声明

子节点 VariableDeclarator

image-20240702100930584

VariableDeclarator 在 AST 中指的是一个特定的节点类型,它用于表示变量声明中的单个变量。在 JavaScript 的 AST 中,VariableDeclarator 节点通常包含以下信息:

  1. id:一个标识符(Identifier)节点,表示变量的名称。
  2. init(可选):一个表达式(Expression)节点,表示变量的初始值。如果变量声明时没有初始值,则此属性可能为空。

两者具有一定的区别

二元运算表达式BinaryExpression

BinaryExpression 是 AST 中的一个节点类型,它代表一个二元运算表达式。二元运算表达式是指包含两个操作数和一个运算符的表达式。在 JavaScript 中,常见的二元运算符包括加法 +、减法 -、乘法 *、除法 /、余数 %、相等 ==、不等于 !=、严格相等 ===、严格不等于 !==、大于 >、小于 <、大于等于 >=、小于等于 <=、逻辑与 &&、逻辑或 || 等。

变量值NumericLiteral

image-20240702101108665

NumericLiteral 是 AST 中的一个节点类型,它代表一个数值字面量。数值字面量是指源代码中直接出现的数字,例如 423.140xFF 等。

标识符的名称Identifier

Identifier 是 AST 中的一个节点类型,它代表一个标识符。在编程语言中,标识符是用户定义的名称,用于标识变量、函数、类、模块或其他用户定义的实体。

image-20240702101147881

对象节点ObjectExpression

image-20240702101609393

ObjectExpression 是 AST 中的一个节点类型,它代表一个对象字面量表达式。在 JavaScript 中,对象字面量是一种用于创建对象的表达式,它由大括号 {} 包围的一组键值对组成,每个键是一个属性名,每个值是一个表达式。

中,对象字面量是一种用于创建对象的表达式,它由大括号 {} 包围的一组键值对组成,每个键是一个属性名,每个值是一个表达式。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值