1

setInterval(fetchData(), 1000*60);エラーFirefoxをスローしながらChromeで動作するのはなぜですか 。fetchdata に変数を渡したい。

   function fetchData(var) {
        .....
    };

    fetchData(var); //run once
    setInterval(fetchData(var), 1000*60); //then repeat

スタックトレース:

[10:26:49.764] Error: useless setInterval call (missing quotes around argument?)
userController@http://localhost:8000/mainx.js:169
invoke@http://localhost:8000/lib/angular.js:2809
instantiate@http://localhost:8000/lib/angular.js:2819
@http://localhost:8000/lib/angular.js:4639
applyDirectivesToNode/nodeLinkFn/<@http://localhost:8000/lib/angular.js:4218
forEach@http://localhost:8000/lib/angular.js:117
nodeLinkFn@http://localhost:8000/lib/angular.js:4203
compositeLinkFn@http://localhost:8000/lib/angular.js:3851
publicLinkFn@http://localhost:8000/lib/angular.js:3763
bootstrap/</<@http://localhost:8000/lib/angular.js:932
Scope.prototype.$eval@http://localhost:8000/lib/angular.js:7840
Scope.prototype.$apply@http://localhost:8000/lib/angular.js:7920
bootstrap/<@http://localhost:8000/lib/angular.js:930
invoke@http://localhost:8000/lib/angular.js:2802
bootstrap@http://localhost:8000/lib/angular.js:929
angularInit@http://localhost:8000/lib/angular.js:904
@http://localhost:8000/lib/angular.js:14527
p.Callbacks/k@http://localhost:8000/lib/jquery-1.8.2.min.js:2
p.Callbacks/l.fireWith@http://localhost:8000/lib/jquery-1.8.2.min.js:2
.ready@http://localhost:8000/lib/jquery-1.8.2.min.js:2
D@http://localhost:8000/lib/jquery-1.8.2.min.js:2
4

2 に答える 2

3

使用する

setInterval(function() {fetchData(var)}, 1000*60); //then repeat

あなたがしていることは、実際にはあなたの引数をまったく渡していません。無名関数でラップする必要があります。

于 2013-03-08T15:34:17.997 に答える
2

この構文は正しくありません。setTimeout や setInterval を使用して、このような変数を渡すことはできません。

setInterval(fetchData(var), 1000*60); //then repeat

代わりに以下を使用してください。

setInterval(function() {
    fetchData(var);
}, 1000*60);
于 2013-03-08T15:34:30.900 に答える