javascript作用域

作者: 啦啦啦_e26f | 来源:发表于2019-02-22 17:46 被阅读57次

    1,[[scope]]:每个javascript函数都是一个对象,对象中有些属性我们可以访问,有些属性我们不能访问,这些属性仅供javascript引擎存取,[[scope]]就是其中一个。[[scope]]就是我们所说的作用域,其中存储了运行期上下文集合(就是作用域链)。
    2,作用域链:[[scope]]作用域中所存储的执行期上下文对象的集合,这个集合呈链式链接,我们把这种链式链接叫做作用域链。
    3,运行期上下文:当函数执行时,会创建一个称为执行期上下文的内部对象。一个执行期上下文定义了函数执行时的环境,函数每次执行时,对应的执行期上下文是独一无二的,所以多次调用一个函数会导致创建多个执行期上下文,当函数执行完毕,它所产生的执行期上下文被销毁。
    4,查找变量的原则:从作用域链的顶端依次往下找。
    下面以一段代码分析:

    function a(){
        function b(){
            var b = 234;
        }
        var a = 123;
        b();
    }
    var glob = 100;
    a();
    //a函数在刚刚定义的时候就有属性a.[[scope]],用于存a的作用域。
    //此时里面只有一个第0位指向Global Object,GO里面有this,window等属性
    //当a函数执行的时候,会产生一个执行期上下文,此时a.[[scope]]会发生变化,
    //第0位装的是AO对象,第一位装的是GO对象,此时就构成了一个作用域链,查找变量的时候就会从顶端的
    //第0位依此往下查找。
    //b函数在刚刚定义的时候就有属性b.[[scope]],用于存b的作用域。
    //此时里面只有一个第0位指向a函数的AO,第一位指向GO
    //当b函数执行的时候,也会产生一个执行期上下文,此时b.[[scope]]会发生变化,
    //第0位装的是自己的AO对象,第一位装的是a函数的AO对象,第二位装的是GO,此时
    //就构成了一个自己的作用域链
    //当函数执行完毕的时候作用域链被销毁,所以函数执行完毕的时候外界就无法访问到函数内部的变量了
    

    下面以图例说明:


    相关文章

      网友评论

        本文标题:javascript作用域

        本文链接:https://www.haomeiwen.com/subject/pxbeyqtx.html