我正在尝试计算两个日期时间字符串之间的时间差。
我有两个输入,其中输入字符串类似于“1:00 PM”和“3:15 PM”。我想知道时间差。因此,对于上面的示例,我想显示3.15。
我所做的:
- 将时间转换为24小时格式。因此,“1:00 PM”变成了“13:00:00”
- 将新时间追加到日期中,如下所示:
new Date("1970-1-1 13:00:00")
- 按以下方式计算差异:
代码:
var total = Math.round(((new Date("1970-1-1 " + end_time) -
new Date("1970-1-1 " + start_time) ) / 1000 / 3600) , 2 )
但总数始终返回整数而不是小数,因此“下午1:00”和“下午3:15”的差异为2而不是2.15。
我还尝试过这个(使用jQuery,但与此无关):
$('#to_ad,#from_ad').change(function(){
$('#total_ad').val( getDiffTime() );
});
function fixTimeString(time){
var hours = Number(time.match(/^(\d+)/)[1]);
var minutes = Number(time.match(/:(\d+)/)[1]);
var AMPM = time.match(/\s(.*)$/)[1];
if(AMPM == "PM" && hours<12) hours = hours+12;
if(AMPM == "AM" && hours==12) hours = hours-12;
var sHours = hours.toString();
var sMinutes = minutes.toString();
if(hours<10) sHours = "0" + sHours;
if(minutes<10) sMinutes = "0" + sMinutes;
return sHours + ':' + sMinutes + ':00';
}
function getDiffTime(){
var start_time = fixTimeString($('#from_ad').val());
var end_time = fixTimeString($('#to_ad').val());
var start = new Date("1970-1-1 " + end_time).getTime(),
end = new Date("1970-1-1 " + start_time).getTime();
return parseInt(((start - end) / 1000 / 3600, 10)*100) / 100;
}
但是total_ad
输入框只显示整数值。
我应该如何解决这个问题?