如何暂停和恢复javascript计时器

use*_*981 3 javascript resume timer

我有这个计时器工作正常,但我需要能够暂停和恢复它之后.如果有人能帮助我,我将不胜感激.

<html>
<head>
<script>
function startTimer(m,s)
    {
        document.getElementById('timer').innerHTML= m+":"+s;
        if (s==0)
            {
               if (m == 0)
                {
                    return;
                }
                else if (m != 0)
                {
                    m = m-1;
                    s = 60;
                }
        }
    s = s-1;
    t=setTimeout(function(){startTimer(m,s)},1000);
}


</script>
</head>

<body>
<button onClick = "startTimer(5,0)">Start</button>

<p id = "timer">00:00</p>
</body>
</html>
Run Code Online (Sandbox Code Playgroud)

Nie*_*sol 5

我根本无法忍受看到setTimeout(...,1000)并期望它正好是1000毫秒.Newsflash:不是.事实上,根据你的系统,它可能在992和1008之间的任何地方,这种差异将加起来.

我将向您展示一个带有增量定时的可暂停定时器,以确保准确性.如果您在计算机的中间更改计算机的时钟,那么唯一不准确的方法就是这样.

function startTimer(seconds, container, oncomplete) {
    var startTime, timer, obj, ms = seconds*1000,
        display = document.getElementById(container);
    obj = {};
    obj.resume = function() {
        startTime = new Date().getTime();
        timer = setInterval(obj.step,250); // adjust this number to affect granularity
                            // lower numbers are more accurate, but more CPU-expensive
    };
    obj.pause = function() {
        ms = obj.step();
        clearInterval(timer);
    };
    obj.step = function() {
        var now = Math.max(0,ms-(new Date().getTime()-startTime)),
            m = Math.floor(now/60000), s = Math.floor(now/1000)%60;
        s = (s < 10 ? "0" : "")+s;
        display.innerHTML = m+":"+s;
        if( now == 0) {
            clearInterval(timer);
            obj.resume = function() {};
            if( oncomplete) oncomplete();
        }
        return now;
    };
    obj.resume();
    return obj;
}
Run Code Online (Sandbox Code Playgroud)

并使用它来开始/暂停/恢复:

// start:
var timer = startTimer(5*60, "timer", function() {alert("Done!");});
// pause:
timer.pause();
// resume:
timer.resume();
Run Code Online (Sandbox Code Playgroud)