0

我有一个循环,我正在计算用户的估计完成时间。

基本上,我希望格式为00:00:00 (hours, minutes,seconds).

我被困在秒数上,我已经能够计算出有多少分和秒,但实际上倒计时我并不擅长......

演示:http: //jsfiddle.net/ZjWkb/

我知道我的问题是秒显示为 60,但是由于 if 语句,它没有倒计时,它只是将其设置为 60,直到它低于 60。

我能做些什么来解决这个问题?

我不希望任何人为我写完整的东西,我只是卡住了:)

4

2 回答 2

1
var count = 1500;
var callsPerSecond = 1;
var delay = 1000;

//count * delay equals 1500000 miliseconds
//1500000 miliseconds == 25 mins, no hours, yet hours are displaying?


function offsetLoop(i, counter, idsRemaining) {

    while (i < counter) {
        var minute = 0;
        var secondsRemaining = (idsRemaining * delay) / 1000;
        var leftSec = 0;
        var hours = 0;

        var remainder = secondsRemaining % 60;
        minute = parseInt(secondsRemaining / 60);


        if (minute > 60) {
        hours = minute % 60;
            minute = parseInt(minute / 60);
        }

        secondsRemaining = secondsRemaining - 1;
        leftSec = remainder;


        secondsRemaining - i;
        if (typeof minute == 'undefined') {
            minute = 0;
        }
        if (typeof hours == 'undefined') {
            minute = 0;
        }
        hours = addZero(hours);
        minute = addZero(minute);
        leftSec = addZero(leftSec);
        log(hours + ":" + minute + ':' + leftSec);
        i++;
        idsRemaining--;
        if (i % callsPerSecond == 0) {
            setTimeout(function () {
                offsetLoop(i, counter, idsRemaining);
            }, delay);
            break;
        }
    }
};

function addZero(num) {
    if (num < 10) {
        num = ('0' + num).slice(-2)
    }
    return num;
}

function log(text) {
    $('#log').html(text);
}

offsetLoop(0, count, count);
于 2013-10-03T06:14:01.067 回答
1

更新了小提琴以包括小时。现在检查。我已经编辑了你的小提琴。似乎工作。链接:http: //jsfiddle.net/ZjWkb/7/

问题出在以下部分:

var minute = (secondsRemaining) / 60;
secondsRemaining = secondsRemaining % 60;
于 2013-10-03T06:16:53.797 回答