最简单的例子理解Javascript闭包

理解Javascript的闭包非常关键,本篇试图用最简单的例子理解此概念。

复制代码
function greet(sth){
    return function(name){
        console.log(sth + ' ' + name);
    }
}

//hi darren
greet('hi')('darren');
复制代码

 

或者可以写成这样:

 

var sayHi = greet('hi');
sayHi('darren');

 

我们要提的问题是:为什么greet的内部函数能使用sth这个变量?

 

其内部大致运作如下:

→ 创建全局上下文

→ 执行var sayHi = greet('hi');语句,创建greet上下文,变量sth存储在greet上下文中。

→ 继续执行greet函数内的语句,返回一个匿名函数,虽然greet上下文从堆栈上消失,但sth变量依旧存在于内存的某个空间。

→ 继续执行sayHi('darren');创建了sayHi上下文,并试图搜寻sth变量,但在sayHi这个上下文中没有sth变量。sayHi上下文会沿着一个作用域链找到sth变量对应的那个内存。 外层函数就像一个闭包,其内部函数可以使用外部函数的变量。

 

一个闭包的简单例子

 

复制代码
function buildFunctions(){
    var funcArr = [];

    for(var i = 0; i < 3; i++){
        funcArr.push(function(){console.log(i)});
    }

    return funcArr;
}

var fs = buildFunctions();
fs[0](); //3
fs[1](); //3
fs[2](); //3
复制代码

 

以上,为什么结果不是0, 1, 2呢?

--因为i作为一个闭包变量,当前值为3,被内部函数使用。要实现想要的效果,可以在遍历的时候每一次遍历创建一个独立的上下文使其不受闭包影响。而自触发函数可以实现独立上下文。

 

复制代码
function buildFunctions(){
    var funcArr = [];

    for(var i = 0; i < 3; i++){
        funcArr.push((function(j){
            return function(){
              console.log(j);
            };
        }(i)));
    }

    return funcArr;
}

var fs = buildFunctions();
fs[0](); //0
fs[1](); //1
fs[2](); //2
复制代码

 

本篇的两个例子正好体现了闭包的2个方面:一个是内部函数使用闭包变量,另一个是把内部函数写在自触发函数中从而避免受闭包影响。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值