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 に答える