javascript - 扩展数组和闭包

标签 javascript methods closures prototype

我正在读一本很棒的 javascript 书,《Javascript Ninja 的 secret 》,作者是 John Resig 和 Bear Bibeault。我到达了他们展示“扩展”Array 类的可能方法的部分。 (因为他们并没有真正扩展它)这是示例中的代码:

function MyArray() {}
MyArray.prototype.length = 0;

(function() {
    var methods = ['push', 'pop', 'shift', 'unshift', 'slice', 'splice', 'join'];
    for (var i = 0; i < methods.length; i++) (function(name) {
        MyArray.prototype[ name ] = function() {
            return Array.prototype[ name ].apply(this, arguments);
        };
    })(methods[i]); //<-This one
})();
var mine = new MyArray();
mine.push(1, 2, 3);

我距离 javascript 专家还很远,有时会发现闭包有问题,所以我的问题是:内部立即函数需要什么?如果我这样写:

for (var i = 0; i < methods.length; i++) {
    MyArray.prototype[methods[i]] = function() {
        return Array.prototype[methods[i]].apply(this, arguments);
    };
};

控制台将记录:ReferenceError:引用未定义的属性方法[i]。这是否意味着 MyArray.prototype 实际上没有分配该方法,直到我调用它的某些方法?或者说这里有什么技巧?非常感谢!

最佳答案

循环的问题是 i 变量与循环的所有迭代中捕获的变量相同,因此最终效果是 MyArray 中的所有原型(prototype)方法code> 最终将调用 methods[methods.length] (因为 i 最终将得到值 methods.length),该值是未定义的!

这就是为什么您需要单独捕获每个 i,并且在循环内创建闭包是一种方法。

查看控制台 jsfiddle看看它的实际效果。

关于javascript - 扩展数组和闭包,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21316025/

相关文章:

javascript - 如何使用javascript从url字符串中提取url文件扩展名

javascript - 输入文本框以及输入效果不断被删除

javascript - 如何使 .getDay 返回数字以外的内容?

javascript - XHR 持久连接,怎么回事?

python - 嵌套函数如何在 Python 中工作?

java - 如果 setOnLongClickListener 已执行,Android 不会执行 setOnTouchListener

C++ 类方法

java - 在面向对象编程 Java 中使用数组和方法

闭包环境中的 Rust 生命周期

javascript - 是什么导致此代码不起作用?