JavaScript代码是由浏览器中的JavaScript解析器来执行的。JavaScript解析器在运行JavaScript代码的时候,分为两步:预解析和代码执行
学习预解析能够让我们知道 为什么在变量声明之前访问变量 值是undefined 为什么在函数声明之前就可以调用函数
-
预解析过程
- JavaScript解析器会在全局环境下查找 var、function关键字,变量只声明不赋值,函数声明不调用。
- 预解析只发生在当前作用域下
-
预解析也叫做变量、函数提升
-
变量提升
定义变量的时候,变量的声明会被提升到当前作用域的最上面,变量的赋值不会提升。
-
函数提升
JavaScript解析器首先会把当前作用域的函数声明提前到整个作用域的最前面
-
变量名和函数名相同,优先执行 函数
-
-
执行过程
- 变量赋值、函数调用、表达式运算等等。
所以解答刚才的 问题:
console.log(num); // 结果是多少?
var num = 10;
等价于:
// 变量提升 只提升声明 不赋值
var num;
console.log(num);
num = 10;
alert(a)
alert(fn)
var a = 1;
function fn(){
return false;
};
等价于
var a
function fn(){
return false;
};
alert(a)
alert(fn)
a = 1;
alert(a);
var a = 1;
alert(a)
function a(){
return false;
}
函数名与变量名同名时,优先执行函数名
var a
function a(){
return false;
}
alert(a);
a = 1;
alert(a)