Resetowanie setTimeout

160

Mam:

window.setTimeout(function() {
    window.location.href = 'file.php';
}, 115000);

Jak mogę, za pomocą funkcji .click, zresetować licznik w trakcie odliczania?

Jason
źródło
Prawdopodobnie możesz użyć istniejącej implementacji debounce.
AturSams

Odpowiedzi:

263

Możesz zapisać odwołanie do tego limitu czasu, a następnie wywołać clearTimeoutto odwołanie.

// in the example above, assign the result
var timeoutHandle = window.setTimeout(...);

// in your click function, call clearTimeout
window.clearTimeout(timeoutHandle);

// then call setTimeout again to reset the timer
timeoutHandle = window.setTimeout(...);
bdukes
źródło
2
Tak dziwne, że .clear()w samym obiekcie timeout nie ma obiektu.
Automatico
16
@ Cort3z to dlatego, że window.setTimeoutzwraca liczbę (identyfikator licznika czasu), a nie „obiekt limitu czasu”.
Dan O
2
Tak, @DanO: dziwne, że setTimeout nie zwraca obiektu Timeout. W kontekście NodeJS tak.
Ki Jéy,
25

clearTimeout () i podaj referencję setTimeout, która będzie liczbą. Następnie wywołaj go ponownie:

var initial;

function invocation() {
    alert('invoked')
    initial = window.setTimeout( 
    function() {
        document.body.style.backgroundColor = 'black'
    }, 5000);
}

invocation();

document.body.onclick = function() {
    alert('stopped')
    clearTimeout( initial )
    // re-invoke invocation()
}

W tym przykładzie, jeśli nie klikniesz elementu body w ciągu 5 sekund, kolor tła będzie czarny.

Odniesienie:

Uwaga: setTimeout i clearTimeout nie są metodami natywnymi ECMAScript, ale metodami JavaScript w globalnej przestrzeni nazw okna.

meder omuraliev
źródło
9

Będziesz musiał zapamiętać limit czasu „Timer”, anulować go, a następnie ponownie uruchomić:

g_timer = null;

$(document).ready(function() {
    startTimer();
});

function startTimer() {
    g_timer = window.setTimeout(function() {
        window.location.href = 'file.php';
    }, 115000);
}

function onClick() {
    clearTimeout(g_timer);
    startTimer();
}
Frank Krueger
źródło
1
Ciekawe, że ta opcja została zignorowana. Wszystkie inne wydają się wymagać powielenia wewnętrznej funkcji timera, co jest mniej niż suche i bolesne, jeśli jest więcej niż kilka linii kodu do dwukrotnego utrzymania ...
brianlmerritt
8
var myTimer = setTimeout(..., 115000);
something.click(function () {
    clearTimeout(myTimer);
    myTimer = setTimeout(..., 115000);
}); 

Coś w tym stylu!

Deniz Dogan
źródło
2

Ten zegar uruchomi alertbox „Hello” po 30 sekundach. Jednak za każdym razem, gdy klikniesz przycisk resetowania timera, wyczyści timerHandle, a następnie ponownie go ustawi. Po uruchomieniu gra się kończy.

<script type="text/javascript">
    var timerHandle = setTimeout("alert('Hello')",3000);
    function resetTimer() {
        window.clearTimeout(timerHandle);
        timerHandle = setTimeout("alert('Hello')",3000);
    }
</script>

<body>
    <button onclick="resetTimer()">Reset Timer</button>
</body>
kaleazy
źródło
2
var redirectionDelay;
function startRedirectionDelay(){
    redirectionDelay = setTimeout(redirect, 115000);
}
function resetRedirectionDelay(){
    clearTimeout(redirectionDelay);
}

function redirect(){
    location.href = 'file.php';
}

// in your click >> fire those
resetRedirectionDelay();
startRedirectionDelay();

tutaj jest rozwinięty przykład tego, co naprawdę się dzieje http://jsfiddle.net/ppjrnd2L/

Biskrem Muhammad
źródło
1
$(function() {

    (function(){

        var pthis = this;
        this.mseg = 115000;
        this.href = 'file.php'

        this.setTimer = function() { 
            return (window.setTimeout( function() {window.location.href = this.href;}, this.mseg));
        };
        this.timer = pthis.setTimer();

        this.clear = function(ref) { clearTimeout(ref.timer); ref.setTimer(); };
        $(window.document).click( function(){pthis.clear.apply(pthis, [pthis])} );

    })();

});
andres descalzo
źródło
1

Aby zresetować licznik czasu, należy ustawić i wyczyścić zmienną licznika czasu

$time_out_handle = 0;
window.clearTimeout($time_out_handle);
$time_out_handle = window.setTimeout( function(){---}, 60000 );
Anwasi Richard Chibueze
źródło
25
Argh, odradzam używanie nazw zmiennych w stylu php w javascript. tak, to zadziała, ale mój Boże, to zagmatwane.
psynnott,
0

Wiem, że to stary wątek, ale dziś go wymyśliłem

var timer       = []; //creates a empty array called timer to store timer instances
var afterTimer = function(timerName, interval, callback){
    window.clearTimeout(timer[timerName]); //clear the named timer if exists
    timer[timerName] = window.setTimeout(function(){ //creates a new named timer 
        callback(); //executes your callback code after timer finished
    },interval); //sets the timer timer
}

i wywołujesz using

afterTimer('<timername>string', <interval in milliseconds>int, function(){
   your code here
});
Clint
źródło