JavaScript代码在js引擎中的运行过程:
第一步:语法分析,就是引擎检查你的代码有没有什么低级的语法错误 。
第二步:预编译,预编译简单理解就是在内存中开辟一些空间,存放一些变量与函数 。
第三步:解释执行,解释执行顾名思义便是执行代码。
预编译分为全局预编译和局部预编译。
全局:
第一步:创建GO对象(Gloabl Object全局对象) 在窗口打开时创建
第二步:所有全局变量声明整体提升,值为undefined。
第三步:所有函数声明(不是表达式!)整体提升,值为函数体。如果变量和函数名称相同,函数将会覆盖掉变量的值。
全局变量:全局变量的声明有两种方式
1.显示声明:
使用var(关键字)+变量名(标识符)的方式在function外部声明,即为全局变量,否则在function声明的是局部变量.
2.隐式声明:
没有使用var,直接给变量赋值,这样会隐式的声明了全局变量。即使该语句是在一个function内,当该function被执行后这个变量就变成了全局变量。
局部:
第一步:创建AO对象(Active Object活动对象),在函数(function)执行的前一刻的时候创建
第二步:函数体内所有变量声明整体提升,值为undefined(注意:形参也属于变量声明)
第三步:使形参、实参值相对应,也就是把实参的值赋给性参
第四步:所有函数声明(不是表达式!)整体提升,值为函数体。如果变量和函数名称相同,函数将会覆盖掉变量的值
函数在执行的前一刻的时候会产生一个执行期上下文,一个执行期上下文所对应的是一个函数在执行期间的环境,每个执行期上下文都是独一无二的,在函数执行结束之后,所对应的执行期上下文就会被销毁,多次调用同一个函数,会产生多个不同的执行期上下文。
例: