Javascript: setTimeout: clearTimeout

#javascript #settimeout

Вопрос:

Я написал универсальную функцию waitFor, которая будет принимать обратный вызов и время ожидания и ждать его. Исходя из моего понимания и наблюдений, мой код будет ждать все это время, а затем сообщать о состоянии. Я хочу отменить тайм-аут, как только решение будет принято. Как мне это сделать?

     var _timer;
    function waitForGeneric(method, max) {
    var start = Date.now();
    return new Promise((resolve, reject) => {
        method();
        function check() {
            result = _connected;
            if (result) {
                console.log('connected to server[connection status]: '   result);
                window.clearTimeout(_timer);
                resolve();
            }            
            else {
                if (Date.now() - start > max) {
                    console.log('waited for 30 seconds for connection[connection status]: '   result);
                    reject();
                }
                else {
                    timer = window.setTimeout(check, 1000);
                }
            }
        }

        check();

    });
}
 

Это правильно?

Комментарии:

1. В принципе, да, и вы можете использовать его без window в своем примере. Оба setTimeout и clearTimeout . А также вам нужно назначить setTimeout _timer , а не timer

2. опечатка, отсутствует подчеркивание: timer = window.setTimeout(check, 1000); для _timer = setTimeout(...

3. @Мистер Джоджо: Ты спас меня! Я

4. И @tarkh, спасибо, что указали на опечатку

Ответ №1:

https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise/then

Я не смогу ответить на этот вопрос до завтра, и у меня не обязательно есть инструменты, чтобы проверить, что вы пытаетесь сделать, чтобы убедиться, что это то, к чему вы стремитесь… но если вы хотите запустить функцию после того, как обещание будет выполнено, вы можете прикрепить .then() метод к экземпляру promise. Кроме того, я могу ошибаться в вашем конкретном случае, но я обычно не вижу window.clearTimeout или window.setTimeout , скорее, у них просто есть соответствующие вызовы функций как clearTimeout и setTimeout .

 var _timer;
function waitForGeneric(method, max)
{
  var start = Date.now();
  return new Promise((resolve, reject) => {
    method();
    function check() {
        result = _connected;
        if (result) {
            console.log('connected to server[connection status]: '   result);
            clearTimeout(_timer);
            resolve();
        }            
        else {
            if (Date.now() - start > max) {
                console.log('waited for 30 seconds for connection[connection status]: '   result);
                reject();
            }
            else {
                timer = setTimeout(check, 1000);
            }
        }
    }

    check();

  }).then(function() {
    clearTimeout(_timer);
  });
}