js作用域链的理解

这篇文章来讨论一下,JavaScript中的作用域链该怎么理解。

要想搞清楚“作用域链”这个概念,我们需要先认识一下什么叫做“自由变量”。

var a = 100
function fn() {
  var b = 200
  console.log(a)
  console.log(b)
}
fn()

上述代码中,console.log(a)要得到变量a,但是我们不难发现,console.log(a)的当前作用域中没有定义a。

大家可以对比一下b,console.log(b)要得到变量b,当前作用域是有定义b的。

当前作用域没有定义的变量,就叫做“自由变量”。

自由变量如何得到?向父级作用域寻找。

如果父级作用域也没找到,就再往上面一层寻找,直到找到全局作用域还是没找到,就宣布放弃。

这种一层一层的关系,就是“作用域链”。

作用域链

再写段代码让大家感受一下:

var a = 100
function F1() {
  var b = 200
  function F2() {
    var c = 300
    console.log(a) // 自由变量,顺着作用域链向父作用域找
    console.log(a) // 自由变量,顺着作用域链向父作用域找
    console.log(c) // 本作用域的变量
  }
  F2()
}
F1()