在javascript中关闭setInterval函数

时间:2012-08-03 17:25:21

标签: javascript closures setinterval

如何在不使用全局变量的情况下使用setInterval?我宁愿将setInerval调用的函数的所有变量都包装在某种闭包中,如下所示:

var wrap = function (f){
 var local1, local2, ...;
 return function () { return f(); }
}

这不起作用,但我的想法是我将wrap(f)而不是f传递给setInterval,以便f的本地人很好地包装不要污染全球范围。

2 个答案:

答案 0 :(得分:4)

javascript没有动态绑定。(此关键字除外)

使用匿名函数可以存档您的想法。 (它叫封闭)

var fnc = function(){
    var local1, local2;

    return function(){
         // using local1, local2
    }
};

setInterval(fnc, 1000);

答案 1 :(得分:2)

我认为你正在寻找类似的东西......

var wrap = function (f){
    var locals = Array.prototype.slice.call(arguments, 1);
    return function () { f.apply(this, locals); }
};


function logger_func() {
    console.log.apply(console, arguments);
}

for (var i = 0; i < 10; i++) {
    setTimeout( wrap(logger_func, i, "foo_" + i), // <-- wrapping i
                i * 1000 );
}

请注意,现代环境允许您将额外参数传递给setTimeout ...

for (var i = 0; i < 10; i++) {
    setTimeout(logger_func, i * 1000, i, "foo_" + i);
}