Передача параметров в функцию setInterval
-
19-08-2019 - |
Вопрос
Подскажите, пожалуйста, как передать параметры в функцию, вызываемую с помощью setInterval
.
Мой пример setInterval(funca(10,3), 500);
это неверно.
Решение
Вам нужно создать анонимную функцию, чтобы настоящая функция не выполнялась сразу.
setInterval( function() { funca(10,3); }, 500 );
Другие советы
Добавьте их в качестве параметров для setInterval:
setInterval(funca, 500, 10, 3);
Синтаксис в вашем вопросе использует eval, что не рекомендуется.
Вы можете передавать параметр (ы) как свойство объекта функции, а не как параметр:
var f = this.someFunction; //use 'this' if called from class
f.parameter1 = obj;
f.parameter2 = this;
f.parameter3 = whatever;
setInterval(f, 1000);
Тогда в вашей функции someFunction
у вас будет доступ к параметрам. Это особенно полезно внутри классов, где область действия автоматически переходит в глобальное пространство, и вы теряете ссылки на класс, который вызвал setInterval для начала. При таком подходе & Quot; параметр2 & Quot; в " someFunction " в приведенном выше примере будет иметь правильную область видимости.
setInterval(function(a,b,c){
console.log(a + b +c);
}, 500, 1,2,3);
//note the console will print 6
//here we are passing 1,2,3 for a,b,c arguments
// tested in node v 8.11 and chrome 69
Вы можете использовать анонимную функцию;
setInterval(function() { funca(10,3); },500);
setInterval(function,milliseconds,param1,param2,...)
Обновлять:2018 год – используйте оператор "распространение"
function repeater(param1, param2, param3){
alert(param1);
alert(param2);
alert(param3);
}
let input = [1,2,3];
setInterval(repeater,3000,...input);
Безусловно, самый практичный ответ - это ответ tvanfosson, все, что я могу сделать, это дать вам обновленную версию с ES6:
setInterval( ()=>{ funca(10,3); }, 500);
Цитировать аргументы должно быть достаточно:
OK --> reloadIntervalID = window.setInterval( "reloadSeries('"+param2Pass+"')" , 5000)
KO --> reloadIntervalID = window.setInterval( "reloadSeries( "+param2Pass+" )" , 5000)
Обратите внимание на одинарную кавычку '
для каждого аргумента.
Протестировано с IE8, Chrome и FireFox
Я знаю, что эта тема очень старая, но вот мое решение о передаче параметров в setInterval
функция.
HTML:
var fiveMinutes = 60 * 2;
var display = document.querySelector('#timer');
startTimer(fiveMinutes, display);
JavaScript:
function startTimer(duration, display) {
var timer = duration,
minutes, seconds;
setInterval(function () {
minutes = parseInt(timer / 60, 10);
seconds = parseInt(timer % 60, 10);
minutes = minutes < 10 ? "0" + minutes : minutes;
seconds = seconds < 10 ? "0" + seconds : seconds;
display.textContent = minutes + ":" + seconds;
--timer; // put boolean value for minus values.
}, 1000);
}
Это работает setInterval("foo(bar)",int,lang);
.... Джон Клайзер , и я пришел к ответу. Р>
Другое решение состоит в том, чтобы передать вашу функцию следующим образом (если у вас есть динамические переменные): setInterval ( 'funca (' + х + ' '+ у +')', 500); р>
Вы можете использовать библиотеку с именем подчеркивания js. Он дает хорошую обертку для метода bind, а также намного более чистый синтаксис. Позволяет вам выполнить функцию в указанной области.
_. bind (функция, область действия, * аргументы)
Эта проблема была бы хорошей демонстрацией использования замыканий. Идея состоит в том, что функция использует переменную внешней области видимости. Вот пример ...
setInterval(makeClosure("Snowden"), 1000)
function makeClosure(name) {
var ret
ret = function(){
console.log("Hello, " + name);
}
return ret;
}
Функция " makeClosure " возвращает другую функцию, которая имеет доступ к внешней области видимости " name " ;. Поэтому, в принципе, вам нужно передать любые переменные в & Quot; makeClosure & Quot; использовать функцию в функции, назначенной для " ret " переменная. В результате setInterval выполнит функцию, назначенную & Quot; ret & Quot ;. Р>