如何计算2个日期时间值之间的时差

时间:2014-01-12 21:11:44

标签: date time

我正在尝试计算2个日期时间字符串之间的时差。

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

我做了什么:

  1. 将时间转换为24小时格式。所以“1:00 PM”变成“13:00:00”
  2. 将新时间添加到如下日期:new Date("1970-1-1 13:00:00")
  3. 计算差异如下:
  4. 代码:

    var total = Math.round(((new Date("1970-1-1 " + end_time) - 
                             new Date("1970-1-1 " + start_time) ) / 1000 / 3600) , 2 )
    

    但是总数总是返回整数而不是小数,所以“1:00 PM”和“3:15 PM”之间的差异是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输入只显示整数值。

    如何解决此问题?

2 个答案:

答案 0 :(得分: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等。

答案 1 :(得分: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();
        }
    }