Javascript中的作用域和上下文深入理解(2)

对每一个执行上下文来说,都有一个作用域连跟它绑定在一起。作用域链包含了执行上下文堆栈中的执行上下文活动对象(activation object,听起来有点绕口)。作用域链决定了变量的访问和标识符的解析。

代码示例:

复制代码 代码如下:


function first(){
    second();
    function second(){
        third();
        function third(){
            fourth();
            function fourth(){
                //代码
            }
        }
    }
}
first();

执行上面的代码,嵌套的函数都会被执行。就上面的代码来说,也会形成一个作用域链,作用域链从顶部到底部的顺序为:fourth, third, second, first, global。函数fourth可以访问全局作用域中的变量,并且可以访问函数third, second, first中定义的任何变量。
有一点需要注意的是,在函数体内,局部变量的优先级高于同名的全局变量。如果在函数内声明的局部变量或函数参数中带有的变量和全局变量重名,那么全局变量就被局部变量所覆盖。
简单来说,每次我们尝试访问一个变量时,程序都会在当前函数作用域内查找变量,如果找不到就沿着作用域链到该函数的上层去查找,直到找到该变量为止,如果找不到则返回undefined。

总结

这篇文章介绍了javascript中上下文和作用域的相关概念,javascript中还有几个比较重要的概念,如闭包等,这些在以后自己弄明白了会写成文章~~

您可能感兴趣的文章:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wgddfs.html