2014-01-12 224 views
5

我正在试图计算jquery中2个日期时间字符串之间的时间差。如何计算jQuery中2个日期时间值之间的时间差

我有2个输入,其中输入字符串是这样的“1:00 PM”,第二个“3:15 PM”我想知道时间差。所以上面的例子中,我想显示3.15

我所做的是

  1. 转换时间为24小时制。因此“1:00 PM”变成了“13:00:00”
  2. 我追加新的时间日期,像这样新的日期(“1970-1-1 13:00:00”)
  3. 然后我计算像相差这么

代码:

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 PM”之间的差为2不是2.15 。

我也试过这种

$(function(){ 

$('#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输入没有显示,但整数值。

我该如何解决这个问题?

感谢

+0

[jquery的比较2倍(HTTP的可能重复: //sackoverflow.com/questions/4929604/comparing-2-times-with-jquery) – isherwood

+0

'3.15 - 1 = 2.15'? – adeneo

+0

jQuery从哪里进入图片?这不是简单的JavaScript吗? – biziclop

回答

0

Math.round四舍五入为最接近的整数乘除,而不是

var start = new Date("1970-1-1 " + start_time).getTime(), 
    end = new Date("1970-1-1 " + end_time).getTime(); 

var total = (parseInt(((start-end)/1000/3600)*100, 10))/100; 

FIDDLE

当你花时间15:15:00和13:00:00减去,你剩下的时间是2.15小时,而不是3.15,即使没有确定只有两位小数,这个例子也会返回2.15,但在其他情况下可能不是这样。
你也可以使用toFixed(2),但这会让你有3.00,而不是3等

+0

由于某些原因,这不适用于我。请检查我的问题,并添加了我正在使用的代码。谢谢 – Mike

+0

在使用它们之前什么格式是“start_time”和“end_time”?初始化后,什么格式是“全部”?它是一个字符串还是毫秒数?请提供更多细节。 – BrianLegg

+0

@BrianLegg - 让我们假设OP不再有这个代码的问题,已经两年了? – adeneo

0

这是我如何计算:

calculateDiff(); 

function calculateDiff(){ 
     _start = "7:00 AM"; 
     _end = "1:00 PM"; 

     _start_time = parseAMDate(_start); 
     _end_time = parseAMDate(_end); 

     if (_end_time < _start_time){ 
      _end_time = parseAMDate(_end,1); 
     } 

     var difference= _end_time - _start_time; 

     var hours = Math.floor(difference/36e5), 
      minutes = Math.floor(difference % 36e5/60000); 
     if (parseInt(hours) >= 0){ 
      if (minutes == 0){ 
       minutes = "00"; 
      } 
      alert(hours+":"+minutes); 
     } 
    } 

    function parseAMDate(input, next_day) { 

     var dateReg = /(\d{1,2}):(\d{2})\s*(AM|PM)/; 

     var hour, minute, result = dateReg.exec(input); 

     if (result) { 
      hour = +result[1]; 
      minute = +result[2]; 

      if (result[3] === 'PM' && hour !== 12) { 
       hour += 12; 
      } 
     } 
     if (!next_day) { 
      return new Date(1970, 01, 01, hour, minute).getTime(); 
     }else{ 
      return new Date(1970, 01, 02, hour, minute).getTime(); 
     } 
    } 
相关问题