Home > Software engineering >  Compare two times range JavaScript
Compare two times range JavaScript

Time:01-21

I want to compare two times and show result as a boolean. I created a function for that. It is working. But when compare the "AM" and "PM" output is wrong.

let Time = "11:25 PM";
let currentTime = "10:00 AM";

console.log(isFutureTime(currentTime, Time));
//Output should be true or false

  function isFutureTime(currentTime, checkTime) {
    if (checkTime.split(" ")[1] == currentTime.split(" ")[1]) {
      if (parseInt(currentTime.split(":")[0]) < parseInt(checkTime.split(":")[0])) {
        return true;
      }
      else if (parseInt(currentTime.split(":")[0]) == parseInt(checkTime.split(":")[0])) {
        if (parseInt(currentTime.split(":")[1].substring(0, 2)) <= parseInt(checkTime.split(":")[1])) {
          return true;
        } else {
          return false;
        }
      } else {
        return false;
      }
    }
    else {
      return false;
    }
  }

CodePudding user response:

You need to check whether currentTime is AM or PM, and return true if it's PM.

...
return currentTime.split(" ")[1] === 'PM';
...

Since you already checked both times are equal, You dont need to check checkTime.

You man declare a variable for currentTime.split(" ")[1] for efficiency.

let Time = "11:25 PM";
let currentTime = "10:00 AM";

console.log(isFutureTime(currentTime, Time));
//Output should be true or false

function isFutureTime(currentTime, checkTime) {
  if (checkTime.split(" ")[1] == currentTime.split(" ")[1]) {
    if (parseInt(currentTime.split(":")[0]) < parseInt(checkTime.split(":")[0])) {
      return true;
    } else if (parseInt(currentTime.split(":")[0]) == parseInt(checkTime.split(":")[0])) {
      if (parseInt(currentTime.split(":")[1].substring(0, 2)) <= parseInt(checkTime.split(":")[1])) {
        return true;
      } else {
        return false;
      }
    } else {
      return false;
    }
  } else {
    return currentTime.split(" ")[1] === 'PM';
  }
}

CodePudding user response:

Alternatively, Javascript Date can natively parse time format you're using, though. So, I just need to concatenate a date string and construct a Date instance for both values. Then compare them.

function isFutureTime(currentTime, checkTime) {
  let date = new Date()
  date = `${date.getFullYear()}-${date.getMonth()   1}-${date.getDate()}`

  return new Date(`${date} ${currentTime}`) > new Date(`${date} ${checkTime}`)
}

const currentTime = '10:00 AM';
const futureTime = '11:25 PM';
const pastTime = '03:15 AM';

console.log(futureTime, '=', isFutureTime(currentTime, futureTime))
console.log(pastTime, '=', isFutureTime(currentTime, pastTime))

  •  Tags:  
  • Related