0

假设我有这种格式的电视节目的开始和持续时间:10:05.
我想要做的是当有人输入程序数据并输入程序的开始时间和持续时间时,我的代码会将它们加在一起并自动填充下一个程序的开始时间。

我试图将这些时间转换为秒,然后在操作后再次将它们转换为格式化时间,但我不知道该怎么做。

function processTime(time) {    
    if (typeof time !== 'undefined') {
        var times = time.split(":");
        var minutes = times[0];
        var seconds = times[1];
        seconds = parseInt(seconds, 10) + (parseInt(minutes, 10) * 60);
    } else {
        var seconds = null;
    }
    return seconds;
}

function createTime(timestamp) {
    var output;
    if (typeof timestamp !== 'undefined') {
        // Problem is here, my timestamp is not standard unix timestamp
        var time = new Date(timestamp * 1000);
        var minutes = time.getMinutes();
        var seconds = time.getSeconds();
        output = minutes + ":" + seconds;
    }
    return output;
}

$progForm.delegate(".program-duration", 'keyup', function() {
        $(this).on('focusout', function() {
            var duration = processTime($(this).val());
            var startTime = processTime($(this).parent().prev().find(".program-time").val());
            if (duration && typeof duration !== 'undefined' && startTime && typeof startTime !== 'undefined') {
                var nextStart = duration + startTime;
                var $nextProgramTime = $(this).parent().parent().next().find(".program-time");
                if (parseInt($nextProgramTime.val()) < 1) {
                    $nextProgramTime.val(createTime(nextStart));
                }
            }
        });
    });


<form>
    <table>
        <tbody class="programs-inputs">
            <tr>
                <td><input type="text" class="program-time timepicker input-mini" name="programs[time][]" placeholder="00:00" /></td>
                <td><input type="text" class="program-duration timepicker input-mini" name="programs[duration][]" placeholder="00:00" /></td>
            </tr>
            <tr>
                <td><input type="text" class="program-time timepicker input-mini" name="programs[time][]" placeholder="00:00" /></td>
                <td><input type="text" class="program-duration timepicker input-mini" name="programs[duration][]" placeholder="00:00" /></td>
            </tr>
        </tbody>
    </table>
</form>
4

2 回答 2

1

unix 时间戳显示自 1970 年以来的时间。由于您只对时间感兴趣,而不是日期,因此 unix 时间戳可能不适合。你可以做你之前做的相反的事情。

var seconds = totalSeconds;
var hours = Math.floor(seconds / 3600);
seconds -= hours * 3600;
var minutes = Math.floor(seconds / 60);
seconds -= minutes * 60;

var timeString = leadingZero(hours) + ':' + leadingZero(minutes) + ':' + leadingZero(seconds);

这不会给你前导零,但这应该很容易修复。

function leadingZero(num) {
    var str = '';
    if (num < 10) {
        str += '0';
    }
    return str + num;
}
于 2013-04-22T21:59:39.183 回答
1

只需使用您的processTime算法的逆:

function createTime(timestamp) {
    if (typeof timestamp == 'number') {
        var seconds = timestamp % 60;
        var minutes = (timestamp - seconds) / 60;
       return ("0"+minutes).slice(-2) + ":" + ("0"+seconds).slice(-2);
    }
}

您最初的尝试是正确的,只是它不是时区证明。虽然new Date(timestamp * 1000);从 Jan 01 1970 00:00:00 UTC构造一个毫秒值,getMinutes()andgetSeconds()方法将返回您当前本地时区中该时间戳的值 - 这可能是半小时的时间。切换到它们的 UTC 等效值 ( .getUTCMinutes(), .getUTCSeconds()) 它将起作用。一旦您需要包含小时甚至完整日期,使用Date对象解决方案将为您节省很多麻烦:-)

于 2013-04-22T22:00:11.203 回答