闭包中js的作用域链【scope chain】

本文详细解释了JavaScript中作用域链的工作原理。介绍了如何在函数中创建活动对象,并解释了这些对象如何与全局变量对象相互作用。此外还讨论了闭包如何影响作用域链。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

话说,还是在继续学习js中【js很博大精深吖- -】
上篇转载了一篇“梦想天空“的文章,也是讲解作用域链的,但是还是给出本篇,也算是自己的学习和巩固。

function compare(value1,value2){
    if(value1 < value2){
        return -1;
    }else if(value1 > value2){
        return 1;
    }else{
        return 0;
    }
}

var result = compare(5,10);

当调用compare时,会创建一个包含arguments,value1和value2的活动对象。全局执行环境的变量对象【包含result和compare】在compare()执行环境的作用域链中则处于第二位。如图:
这里写图片描述

后台的每个执行环境都有一个表示变量的对象——变量对象。全局环境的变量对象始终存在,而像compare()函数这样的局部环境的变量对象,则只在函数执行过程中存在。在创建compare()函数时,会创建一个预先包含全局变量对象的作用域链,这个作用域链被保存在内部的[[scope]]属性中,当调用compare()函数时,会为函数创建一个执行环境,然后通过复制函数的[[scope]]属性中的对象构建起执行环境的作用域链。此后,又有一个活动对象(在此作为变量对象使用)被创建并别推入执行环境作用域链的前端。对于这个例子中compare()函数的执行环境而言,其作用域链中包含两个变量对象:本地活动对象和全局变量对象。显然,作用域链本质上是一个指向变量对象的指针列表,它只引用但不实际包含对象。

无论什么时候在函数中访问一个变量时,就会从 作用域链中搜索具有相应名字的变量。一般来讲,当函数执行完毕后,局部活动对象就会被销毁,内存中仅保存全局作用域(全局执行环境的变量对象)。但是闭包的情况和此不同。

在另一个函数中定义的函数会将包含函数【即外部函数】的活动对象添加到它的作用域链中。

function  createComparisonFunction(property){
    return function(obj1,obj2){
        var value1 = obj1[property];
        var value2 = obj2[property];

        if(value1 < value2){
            return -1;
        }else if(value1 > value2){
            return 1;
        }else{
            return 0;
        }
    }
}

var compare = createComparisonFunction("name");

var result = compare({name:'Nicholas'},{name:'Greg'});

那么呢,其产生的作用域链间关系如下图:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值