我使用以下代码来获取hrs,minutes和seconds两个日期之间的差异,稍后我将在数据库中将其保存为字符串字段。所以我想知道是否可以使用Moment.js库或任何功能上的Javascript来获得数据库中保存的所有日期差异的总小时数,分钟数和秒数(例如02:24:33 + 03: 12:20 + 12:33:33)作为最后一名HH:MM:SS考虑到总和小时数超过24小时HH可能超过24?感谢
$('.set-start-time').on("dp.change",function (e) {
$('.set-end-time').data("DateTimePicker").setMinDate(e.date);
});
$('.set-end-time').on("dp.change",function (e) {
$('.set-start-time').data("DateTimePicker").setMaxDate(e.date);
var now = $('.set-start-time').data('DateTimePicker').getDate().toLocaleString();
var then = $('.set-end-time').data('DateTimePicker').getDate().toLocaleString();
console.log(moment.utc(moment(then,"DD/MM/YYYY HH:mm:ss").diff(moment(now,"DD/MM/YYYY HH:mm:ss"))).format("HH:mm:ss"));
//Output here come in format ex. 02:42:33
});
答案 0 :(得分:1)
这可能为时已晚,但这可能会有所帮助:
http://jsfiddle.net/8s8v3evf/8/
<强> TL;博士强> 一旦你有了你的差异:
function zeroPad(num, places) {
var zero = places - num.toString().length + 1;
return Array(+(zero > 0 && zero)).join("0") + num;
}
function diffAsString(diff_ms) {
var hours = Math.floor(diff_ms / 3600000);
diff_ms -= (hours * 3600000);
var minutes = Math.floor(diff_ms / 60000);
diff_ms -= (minutes * 60000);
var seconds = Math.floor(diff_ms / 1000);
return zeroPad(hours, 2) + ':' + zeroPad(minutes, 2) + ':' + zeroPad(seconds, 2);
}