javascript - js高程中闭包讲解的问题?
黄舟
黄舟 2017-04-10 18:02:05
[JavaScript讨论组]

《js高级程序设计》(第三版)7.2.1中的闭包案例:

以下是对代码的解释

可是实际运行时的结果是这样的:

即便是这样:

运行的结果还是与书中所说的结果[10,10,10,10,10,10,10,10,10,10]不同。


接下来是是书中的改进代码:

书中给出的运行结果应该是:[0,1,2,3,4,5,6,7,8,9],而这段代码的实际运行结果是:

求解

黄舟
黄舟

人生最曼妙的风景,竟是内心的淡定与从容!

全部回复(7)
大家讲道理

题主,你需要一颗清醒的头脑,弄清楚每次Foo()之后return的是什么。

第一张console图,返回了resultresult是一个数组,存放了10个闭包。
第二张console图,返回了resultresult是一个数组,存放了10个自运行函数,自运行函数是什么?其实就是函数运行的返回值,也就是i
第三张console图,依旧返回了resultresult依旧是一个数组,依旧存放了10个自运行函数,但这10个自运行函数的返回值却是10个闭包。

至于什么时候是[1,2,3..],什么时候是[10,10,10..],要看i保存的时间。如果i产生于外部函数Foo执行期间,并在这期间调用闭包将产生的值存放于result中,那么结果就是[1,2,3..]。如果Foo运行结束了,这时候i的值变成10了,再调用闭包保存i的值,这时候结果自然是[10,10,10..]了。

PHP中文网

返回函数数组 数组里面都是函数,要得到i的值还需要result[i]()这样运行一次

伊谢尔伦


这个图的result[i]接受的是函数的返回值,这里匿名函数自执行了,i为循环过程中的值,结果显然如题主那样了。
题主应该把原书的代码中,返回的函数数组,在循环后通过遍历一次执行数组中每个函数,这样返回的i就全是10了。

同样,最后的例子返回的函数数组,原书的意思也是遍历结果数组后,数组中每个函数返回的i值是[0,1,2,3,4,5,6,7,8,9]

伊谢尔伦

function foo() {
    var result = []; 
    for(let i=0;i<10;i++) { 
        result[i] = function(num) {
        return num
        }(i) 
    }  
    return result
}
PHP中文网
Function.prototype.bind = function (scope) {
    var fn = this;
    return function () {
        return fn.apply(scope);
    };
}

函数返回函数

阿神

Foo()[9]();
就能看到书中的意图了

ringa_lee

我觉得对闭包最好的解释是:闭包中对外部变量的使用都是通过引用传递,而不是通过值传递。

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号