JavaScript(作用域)

1.作用域精解
  • [[scope]]:每个JavaScript函数都是一个对象,对象中有些属性我们可以访问,但有些不可以,这些属性仅供JavaScript引擎存取,[[scope]]就是其中一个
  • [[scope]]指的就是我们所说的作用域,其中存储了运行期上下文的集合
  • 作用域链:[[scope]]中所存储的执行期上下文对象的集合,这个集合呈链式链接,我们把这种链式链接叫做作用域
  • 运行期上下文:当函数执行时,会创建一个称谓执行期上下文的内部对象。一个执行期上下文定义了一个函数执行时的环境,函数每次执行时对应的执行上下文都是独一无二的,所以多次调用一个函数会导致创建多个执行上下文,当函数执行完毕,它所产生的执行期上下文被销毁。
  • 变量查找:从作用域的顶端依次向下查找

2.例子

function a() {
    function b() {
        function c() {

        };
        c();
    };
    b();
}
a();
/**
 * a defined  a.[[scope]] --> 0:GO
 * a doing    a.[[scope]] --> 0:aAO
 *                            1:GO
 * b defined  b.[[scope]] --> 0:aAO
 *                        --> 1:GO
 * b doing    b.[[scope]] --> 0:bAO
 *                        --> 1:aAO
 *                        --> 2:GO
 * c defined  c.[[scope]] --> 0:bAO
 *                        --> 1:aAO
 *                        --> 2:GO
 * c doing  c.[[scope]]   --> 0:cAO
 *                        --> 1:bAO
 *                        --> 2:aAO
 *                        --> 3:GO
 *
 */




猜你喜欢

转载自blog.csdn.net/u012691505/article/details/80566031