How to compare two datetime in javascript?

Refresh

December 2018

Views

12.5k time

1

I tried create markers by JSON parse from C #.I have a small problem about datetime compare in javascript.

  var nowDate= new Date();

  var LastTenMin= new Date(nowDate.getFullYear(), nowDate.getMonth(), nowDate.getDate(),nowDate.getHours(),nowDate.getMinutes()- 10);

 var Time1= data2.LastRecordTime;

 var image2;

  var status;


  if (new Date(Time1) < new Date(LastTenMin)) {


  image2 = '/Images/truckOnline.png';


   status = "Truck is online."+"\n"+"Last seen:"+" "+Time1,

   }

 else {


   image2 = '/Images/truckOffline.png';
   status = "Truck is offline"+"\n"+"Last seen:"+" "+Time1,


            }

else is not working ! There are truckOnline markers on google map.Where is my mistake ?

And LastRecordTime format like this in SQL : 04.12.2013 01:03:00

    LastRecordTime=CONVERT(VARCHAR(10), [ReadTimeColumn], 104) + ' ' + CONVERT(VARCHAR(8), [ReadTimeColumn],108)

4 answers

2

Мехмет,

Похоже, что вы сделали опечатку:

  var LastTenMin= new Date(nowDate.getFullYear(), nowDate.getMonth(), nowDate.getDate(),nowDate.getHours(),nowDate.getMinutes(),- 10);

Должно быть (обратите внимание на запятую):

  var LastTenMin= new Date(nowDate.getFullYear(), nowDate.getMonth(), nowDate.getDate(),nowDate.getHours(),nowDate.getMinutes() - 10);

Кроме того, вы пытаетесь создать новый объект даты из объекта даты, это неверно:

 new Date(LastTenMin)

А вот более полное решение:

var nowDate= new Date();
var Time1 = new Date("04/12/2013 01:03:00");
var LastTenMin= new Date(nowDate.getFullYear(), nowDate.getMonth(), nowDate.getDate(), nowDate.getHours(), nowDate.getMinutes() - 10);

// Should return true 
console.log(Time1 < LastTenMin);

// Change the year to a point in the future
Time1 = new Date("04/12/2014 01:03:00");

// Shold return false
console.log(Time1 < LastTenMin);

// So your original conditional should look like this:
if (Time1 < LastTenMin) {
    image2 = '/Images/truckOnline.png';
    status = "Truck is online."+"\n"+"Last seen:"+" "+Time1;
} else {
    image2 = '/Images/truckOffline.png';
    status = "Truck is offline"+"\n"+"Last seen:"+" "+Time1;
}

// And a more concise form:
var isOnline = !(Time1 < LastTenMin);
var image2 = isOnline ? '/Images/truckOnline.png' : '/Images/truckOffline.png';
var status = "Truck is " + (isOnline ? "Online" : "Offline") + "." + "\n" + "Last seen:" + " " + Time1

Вот решение без комментариев:

var nowDate= new Date();
var Time1 = new Date(data2.LastRecordTime);
var LastTenMin= new Date(nowDate.getFullYear(), nowDate.getMonth(), nowDate.getDate(), nowDate.getHours(), nowDate.getMinutes() - 10);
var isOnline = !(Time1 < LastTenMin);
var image2 = isOnline ? '/Images/truckOnline.png' : '/Images/truckOffline.png';
var status = "Truck is " + (isOnline ? "Online" : "Offline") + "." + "\n" + "Last seen:" + " " + Time1

Все мое решение при условии, что строка, содержащаяся в data2.LastRecordTime в формате: «MM.DD.YYYY HH: MM: SS».

0

Я решил по SQL.

Я установил новый Колум для разностнога минуты между сейчас и ReadTime.

    DifferenceMinute=DATEDIFF(MINUTE,ReadTime,GETDATE())



if(DifferenceMinute>10)

 { 

  bla bla

  }

 else 
 {

 bla bla

  }
1

Это будет звучать как увильнуть, но я хотел бы перейти к MomentJS так что вы получите следующий код:

var Time1 = moment("04/12/2013 01:03:00");
var lastTenMin = moment().subtract({minutes: 10});

if(Time1.isBefore(lastTenMin)){
    image2 = '/Images/truckOnline.png';
    status = "Truck is online."+"\n"+"Last seen:"+" "+Time1.local();
} else {
    image2 = '/Images/truckOffline.png';
    status = "Truck is offline"+"\n"+"Last seen:"+" "+Time1.local();
}    

Помните, что JavaScript имеет случайный вне по-одному вопросов на сегодняшний день и месяц (один с нуля, другой один на основе). Проблема, скорее всего, в этой строке:

var LastTenMin= new Date(nowDate.getFullYear(), nowDate.getMonth(), nowDate.getDate(),nowDate.getHours(),nowDate.getMinutes()- 10);

При переключении на MomentJS, такого рода проблемы исчезнут. Я потерял много часов борьбы с этими же вопросами, поэтому я понимаю!

PS Попробуйте функцию форматирования календаря () ... это может быть хорошо подходит в вашем пользовательском интерфейсе.

0

Для сравнения даты со временем Javascriptмы должны передать их в Dateобъект как «гггг / мм / дд чч: мм» формат , например , как "2014/05/19 23:20" . Тогда вы можете просто сравнить их с> или <меньше символа в соответствии с вашими бизнес - правила. Пожалуйста , см приведены ниже код для большего понимания.

$(function () {

    $("input#Submit").click(function () {
        var startDateTime = $("input[name='StartDateTime']").val();
        var endDateTime = $("input[name='EndDateTime']").val();

        var splitStartDate = startDateTime.split(' ');
        var splitEndDate = endDateTime.split(' ');

        var startDateArray = splitStartDate[0].split('/');
        var endDateArray = splitEndDate[0].split('/');

        var startDateTime = new Date(startDateArray[2] + '/ ' + startDateArray[1] + '/' + startDateArray[0] + ' ' + splitStartDate[1]);
        var endDateTime = new Date(endDateArray[2] + '/ ' + endDateArray[1] + '/' + endDateArray[0] + ' ' + splitEndDate[1]);

        if (startDateTime > endDateTime) {
            $("#Error").text('Start date should be less than end date.');
        }
        else {
            $("#Error").text('Success');
        }
    });

});

Вы также можете увидеть рабочую демо здесь