JavaScript基础概念之----作用域链

Posted adhehe

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript基础概念之----作用域链相关的知识,希望对你有一定的参考价值。

也称:词法作用域

javascript查找变量关联的值时,会遵循一个查找链,这个链是基于作用域的层次结构的。

var a = ‘hello‘;

var func1 = function(){
    var func2 = function(){
        console.log(a);
    }
}

//hello

如上图,查找过程如下:

1、在func2函数中查找变量a,如果找到了,直接输出值,如果没有找到,转到第2步

2、在func2的父函数 func1函数中继续查找,如果找到了,直接输出值,如果没有找到,转到第3步

3、继续在全局作用域中查找,如果找到了,直接输出值,如果没有找到,输出undefined

 

作用域链查找 返回第一轮值。当在作用域链内最近位置查到变量时,查找即结束,不管作用域链顶部是否还有相同的变量名称

var a = 1;
var func1 = function(){ var a = 2; var func2 = function(){ var a = 3; console.log(a);//输出 3。局部变量a在作用域内是第一个被查找到的,因此不再查找其余的 } }

作用域链 是根据函数定义时的位置决定的,而不是在调用时确定的。

正因为 作用域链是在函数调用之前创建,所以才可以创建闭包。

 


以上是关于JavaScript基础概念之----作用域链的主要内容,如果未能解决你的问题,请参考以下文章

JavaScript基础概念之----作用域

JavaScript深入之作用域链(转)

JavaScript之作用域链

Javascript执行环境作用域链

javascript 之作用域链-10

JS基础之——作用域和作用域链