JavaScript中的预解析

JavaScript代码是有浏览器的JavaScript引擎(也叫JS解释器)来执行的。JavaScript引擎在运行JavaScript代码时,分为两步:预解析和代码执行。

1.预解析过程

  • JavaScript引擎会在全局环境下查找var、function关键字,变量只声明不赋值,函数声明不调用。
  • 预解析只发生在当前作用域下。

2.预解析也叫变量提升、函数提升

  • 变量提升

定义变量的时候,变量的声明会被提升到当前作用域的最上面,变量的赋值不会提升。

  • 函数提升

JS引擎首先会把当前作用域内的函数声明提升到整个作用域的最前面。

  • 变量名和函数名相同,优先执行函数。

3.执行过程

  • 变量赋值、函数调用、表达式运算等

JavaScript中的预解析

等价于:

JavaScript中的预解析

变量num只提升不赋值。

4.几个案例

案例1 :

JavaScript中的预解析

案例2:

JavaScript中的预解析

案例3:

JavaScript中的预解析

案例4:

JavaScript中的预解析

案例5:

JavaScript中的预解析