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在作用域内是第一个被查找到的,因此不再查找其余的 } }

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

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

扫描二维码关注公众号,回复: 3572750 查看本文章

猜你喜欢

转载自www.cnblogs.com/adhehe/p/9785019.html
今日推荐