1:[[scope]]属性
首先了解[[scope]]属性,这是一个内部属性,只允许JavaScript引擎存取。
[[scope]]指的就是我们所说的作用域,其中存储了运行期上下文的集合。
2:作用域链
[[scope]]中存储的执行期上下文对象的集合,这个集合城链式链接,我们把这种链式链接叫做作用域链。
3:运行期上下文
当函数执行时,会创建一个称为执行期上下文的内部对象。一个执行期上下文定义了一个函数执行时的环境,函数每执行时对应的执行期上下文都是独一无二的。所以多次调用一个函数会导致创建多个执行期上下文。当函数执行完毕时,执行上下文被销毁。
注意每个函数执行一次都会产生一个独一无二的执行期上下文(AO)
4:查找变量
从作用域链的顶端依次向下查找
例子
function a(){
function b(){
var b = 234;
}
var a = 123;
b();// b函数在a函数里面执行
}
var glob = 100;
a();
当a函数被定义时,scope chain发生如下过程:
a: scope chain [0] --> Global Object(GO)
当a被执行时:
a: scope chain [0] --> Activation Object(AO)
scope chain [1] --> Global Object(GO)
当b函数被创建时:scope chain发生如下过程:
b:scope chain [0] --> Activation Object(AO)
scope chain [1] --> Global Object(GO)
注意:b创建时就保存了a的作用域的引用
当b函数执行时:
b:scope chain [0] --> Activation Object(AO) // b自身产生的AO
scope chain [1] --> Activation Object(AO) // b保存的a的AO的引用
scope chain [2] --> Global Object(GO)