使用时间戳的差值来计算时间,比如计算 1669996800000 到 1675840401000
下面的函数返回两组数据,第一组是转为的 日 - 时 - 分 - 秒 第二组是 转为的 年 - 月 - 日
function calculationTime(startTime,endTime) {//参数传入两个时间戳
var mss = Math.abs(startTime- endTime); //毫秒差值
//time1 //日 - 时 - 分 - 秒
var days = parseInt(mss / (1000 * 60 * 60 * 24));
var hours = parseInt((mss % (1000 * 60 * 60 * 24)) / (1000 * 60 * 60));
var minutes = parseInt((mss % (1000 * 60 * 60)) / (1000 * 60));
var seconds = parseInt((mss % (1000 * 60)) / 1000);
//time2 //年 - 月 - 日
var yearLevelValue = 365 * 24 * 60 * 60 * 1000;
var monthLevelValue = 30 * 24 * 60 * 60 * 1000;
var dayLevelValue = 24 * 60 * 60 * 1000;
var Y = parseInt(Math.floor(parseInt(mss) / yearLevelValue));
var M = parseInt(Math.floor(parseInt(mss - Y * yearLevelValue) / monthLevelValue));
var D = parseInt(Math.floor(parseInt(mss - Y * yearLevelValue - M * monthLevelValue) / dayLevelValue));
//给时间补零操作
function setDb(num) {
return num < 10 ? '0' + num : '' + num
}
var timer = {
time1: {
days,
hours: setDb(hours),
minutes: setDb(minutes),
seconds: setDb(seconds),
},
time2: {
year: Y,
month: setDb(M),
day: setDb(D)
}
};
//返回对象
return timer;
},