Параметры пропуска в функции setInterval

Посоветуйте, пожалуйста, как передать параметры в функцию, вызываемую с помощью setInterval.

Мой пример setInterval(funca(10,3), 500); неверен.

Ответ 1

Вам нужно создать анонимную функцию, чтобы фактическая функция не выполнялась сразу.

setInterval( function() { funca(10,3); }, 500 );

Ответ 2

теперь с ES5, метод связывания Прототип функции:

setInterval(funca.bind(null,10,3),500);

Ссылка здесь

Ответ 3

Добавьте их как параметры в setInterval:

setInterval(funca, 500, 10, 3);

В синтаксисе вашего вопроса используется eval, что не рекомендуется.

Ответ 4

Вы можете передать параметр как свойство объекта функции, а не как параметр:

var f = this.someFunction;  //use 'this' if called from class
f.parameter1 = obj;
f.parameter2 = this;
f.parameter3 = whatever;
setInterval(f, 1000);

Затем в вашей функции someFunction у вас будет доступ к параметрам. Это особенно полезно внутри классов, где область автоматически попадает в глобальное пространство, и вы теряете ссылки на класс, который называется setInterval для начала. При таком подходе параметр "parameter2" в "someFunction", в приведенном выше примере, будет иметь правильную область видимости.

Ответ 5

     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

Ответ 6

Вы можете использовать анонимную функцию;

setInterval(function() { funca(10,3); },500);

Ответ 7

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);

Ответ 8

Самым практичным ответом является тот, который дан tvanfosson, все, что я могу сделать, это дать вам обновленную версию с ES6:

setInterval( ()=>{ funca(10,3); }, 500);

Ответ 9

Котировка аргументов должна быть достаточной:

OK --> reloadIntervalID = window.setInterval( "reloadSeries('"+param2Pass+"')" , 5000)

KO --> reloadIntervalID = window.setInterval( "reloadSeries( "+param2Pass+" )" , 5000)

Обратите внимание на одиночную кавычку ' для каждого аргумента.

Протестировано с помощью IE8, Chrome и FireFox

Ответ 10

Я знаю, что эта тема такая старая, но вот мое решение о передаче параметров в функции 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);
}

Ответ 11

Это работает setInterval("foo(bar)",int,lang);.... Jon Kleiser привести меня к ответу.

Ответ 12

Другое решение состоит в том, чтобы передать вашу функцию (если у вас есть динамические вары): setInterval ( 'funca (' + х + ' '+ у +')', 500);

Ответ 13

Вы можете использовать библиотеку под названием underscore js. Это дает хорошую обертку в методе связывания и также является более чистым синтаксисом. Позволяя вам выполнить функцию в указанной области.

http://underscorejs.org/#bind

_. bind (function, scope, * arguments)

Ответ 14

Эта проблема была бы хорошей демонстрацией использования крышек. Идея состоит в том, что функция использует переменную внешней области видимости. Вот пример...

setInterval(makeClosure("Snowden"), 1000)

function makeClosure(name) {
var ret

ret = function(){
    console.log("Hello, " + name);
}

return ret;
}

Функция "makeClosure" возвращает другую функцию, которая имеет доступ к внешней области видимости переменной "name". Таким образом, в основном вам нужно передать любые переменные в функцию "makeClosure" и использовать их в функции, назначенной переменной "ret". В результате setInterval выполнит функцию, назначенную для "ret".

Ответ 15

Добавление скобок после анонимной функции, похоже, делает трюк:

function clock() {
    n = 10;

    while(--n) {
        setInterval(function() {  
            console.log(n);
        }(n), 1000);
    }
}