解析代码树
// 声明一个变量 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;
},
// 对象定义结束
};
ast 常见语法类型
变量 VariableDeclaration
对比 ast 语法树和 js 代码,首先注意到的是 VariableDeclaration
在 JavaScript 等编程语言中指的是变量声明
子节点 VariableDeclarator
VariableDeclarator
在 AST 中指的是一个特定的节点类型,它用于表示变量声明中的单个变量。在 JavaScript 的 AST 中,VariableDeclarator
节点通常包含以下信息:
id
:一个标识符(Identifier)节点,表示变量的名称。init
(可选):一个表达式(Expression)节点,表示变量的初始值。如果变量声明时没有初始值,则此属性可能为空。
两者具有一定的区别
二元运算表达式BinaryExpression
BinaryExpression
是 AST 中的一个节点类型,它代表一个二元运算表达式。二元运算表达式是指包含两个操作数和一个运算符的表达式。在 JavaScript 中,常见的二元运算符包括加法 +
、减法 -
、乘法 *
、除法 /
、余数 %
、相等 ==
、不等于 !=
、严格相等 ===
、严格不等于 !==
、大于 >
、小于 <
、大于等于 >=
、小于等于 <=
、逻辑与 &&
、逻辑或 ||
等。
变量值NumericLiteral
NumericLiteral
是 AST 中的一个节点类型,它代表一个数值字面量。数值字面量是指源代码中直接出现的数字,例如 42
、3.14
、0xFF
等。
标识符的名称Identifier
Identifier
是 AST 中的一个节点类型,它代表一个标识符。在编程语言中,标识符是用户定义的名称,用于标识变量、函数、类、模块或其他用户定义的实体。
对象节点ObjectExpression
ObjectExpression
是 AST 中的一个节点类型,它代表一个对象字面量表达式。在 JavaScript 中,对象字面量是一种用于创建对象的表达式,它由大括号 {}
包围的一组键值对组成,每个键是一个属性名,每个值是一个表达式。
中,对象字面量是一种用于创建对象的表达式,它由大括号 {}
包围的一组键值对组成,每个键是一个属性名,每个值是一个表达式。