JavaScript词法分析步骤

JavaScript代码运行前有一个类似编译的过程即词法分析,词法分析主要有三个步骤:

  • 分析参数
  • 再分析变量的声明
  • 分析函数声明

具体步骤如下:

  • 函数在运行的瞬间,生成一个活动对象(Active Object),简称AO
  • 第一步:分析参数:
  1. 函数接收形式参数,添加到AO的属性,并且这个时候值为undefine,即AO.age=undefine
  2. 接收实参,添加到AO的属性,覆盖之前的undefine
  • 第二步:分析变量声明:如var age;或var age=18;
  1. 如果上一步分析参数中AO还没有age属性,则添加AO属性为undefine,即AO.age=undefine
  2. 如果AO上面已经有age属性了,则不作任何修改
  • 第三步:分析函数的声明:
  • 如果有function age(){}把函数赋给AO.age ,覆盖上一步分析的值

应用例子

var age = 18;
function foo(){
  console.log(age);
  var age = 22;
  console.log(age);
}
foo();       运行结果undefined,22

 分析:第一步,没有形参和实参,第二步AO没有age属性,AO.age=undefined,第三步,没有函数的声明。开始执行,第一个打印undefined,var age=22赋值给age,

第二次打印出22

猜你喜欢

转载自www.cnblogs.com/weidaijie/p/10344366.html