首先,我们来看一段简单js的执行结果:
function foo() {
console.log( a );
}
function bar() {
var a = 3;
foo();
}
bar();
var a = 2;
bar();
思
考
时
间
答案是:
undefined
2
这里就涉及到js的词法作用域的概念了:当定义了一个函数后,当前的作用域就会被保存下来,并且成为函数内部状态的一部分。
因此,当函数foo在定义的时候,当前作用域(即全局作用域)就被保存下来了,函数内的变量a即全局作用域下。
第一次执行函数bar时,全局变量a还没有初始化(因为存在变量提升,所以此时a为undefined),所以输出为undefined。
而第二次执行函数bar时,给全局变量赋值为2,所以输出为2.