[[scope]]
每个JavaScript函数都是一个对象,对象中有些属性我们可以访问, 有些不可以,这些属性仅供javaScript引擎存取,[[scope]]就是其中一个[[scope]]指的就是我们所说的作用域,其中存储了运行期上下文的集合。
作用域链
[[scope]]中所存储执行期上下文对象的集合,这个集合呈链式连接,我们把这种链式连接叫作用域链
运行期上下文
当函数执行时,会创建一个称之为 执行期上下文 (AO对象) 的内部对象。一个执行期上下文定义了一个函数执行时的环境,函数每次执行时对应的执行上下文都是独一无二的,所以多次调用一个函数会导致创建多个执行上下文,当函数执行完毕,他所产生的执行上下文被销毁。
查找变量
在那个函数查找变量 就从那个函数的作用域链的顶端依次向下查找
function a(){}
var glob = 100;
a();
a 定义
a.[[scope]] —> 0:GO
a 执行
产生一个执行期上下文 AO 放在作用域链的顶端
a.[[scope]] —> 0:AO
1:GO
从作用域链的顶端依次向下查找
所以 要访问一个变量 先从[[scope]]的 第0位开始找 即AO对象
第0位未找到 在找 第1位 即GO对象
function a(){
function b(){
var b = 234;
}
var a = 123;
b()
}
a()
b函数定义时 继承了a函数的 作用域链
b函数执行时 产生一个AO对象 放在作用域链的顶端
b函数执行后 产生的一个AO对象被销毁 等待下一次执行
a 的AO对象 与 b的作用域链的 第1项 是否是同一个AO对象
function a(){
function b(){
var bb = 234;
aa = 0;
}
var aa = 123;
b();
console.log(aa);//0
}
a()
a 定义(define) a.[[scope]] --> 0:GO
a 执行(doing) a.[[scope]] --> 0:aAO
1:GO
b 定义(define) b.[[scope]] --> 0:aAO
1:GO
b 执行(doing) b.[[scope]] --> 0:bAO
1:aAO
2:GO
b 执行完 b.[[scope]]销毁bAO 等待下一次执行 产生一个新的作用域链
a 执行完 a.[[scope]]销毁aAO 等待下一次执行 产生一个新的作用域链
如果 aa = 123 说明不是同一个AO对象
是同一个AO对象