假设我有这种格式的电视节目的开始和持续时间: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>