JS作用域链

JS作用域链 如题1

var a = 1 function fn1(){ function fn2(){ console.log(a) } function fn3(){ var a = 4 fn2() } var a = 2 return fn3 } var fn = fn1() fn() //输出多少

题中fn()输出为2
说明:fn1()执行到最后是fn2(),fn2()内部没有定义变量,所以从当前函数所在的作用域去找,即f1()中查找(fn2()为fn1()的内部函数),fn1()中a=2,所以输出为2. 题2
var a = 1 function fn1(){ function fn3(){ var a = 4 fn2() } var a = 2 return fn3 } function fn2(){ console.log(a) } var fn = fn1() fn() //输出多少

题中fn()输出为1
说明:执行fn1()后最终的调用函数为fn2(),而fn2()中没有定义a,所以从它所在的作用域寻找变量a,不难发现它的作用域是全局,全局变量a为1,所以结果输出为1. 题3:
var a = 1 function fn1(){function fn3(){ function fn2(){ console.log(a) } var afn2() a = 4 } var a = 2 return fn3 } var fn = fn1() fn() //输出多少

【JS作用域链】结果为:undefined
说明:执行结果为fn2(),它内部没有定义a,所以从它的作用域去寻找--即fn3(),因为a=4的赋值语句在fn2()后执行,所以此时a只是定义了还没有赋值,所以a为undefined. 总结:
  • 函数在执行的过程中,先从自己内部找变量
  • 如果找不到,再从创建当前函数所在的作用域去找, 以此往上
  • 注意找的是变量的当前的状态

    推荐阅读