如何在 JavaScript 中比較兩個日期

Kirill Ibrahim 2023年10月12日
  1. JavaScript 用比較運算子比較兩個日期
  2. JavaScript 用 getTime() 方法比較兩個日期
  3. JavaScript 使用 valueOf() 方法比較兩個日期
  4. JavaScript 使用 Number() 函式比較兩個日期
  5. JavaScript 用一元運算子 + 比較兩個日期
如何在 JavaScript 中比較兩個日期

JavaScript 內建了日期的比較系統,讓比較變得非常簡單。

本教程介紹瞭如何在 JavaScript 中比較兩個日期的不同方法。每一種方法都會有一個程式碼示例,你可以在自己的機器上執行。

JavaScript 用比較運算子比較兩個日期

我們可以直接用 JavaScript 中的比較運算子如 <, <=, >>= 來比較兩個日期。

var date1 = new Date('2020-10-23');
var date2 = new Date('2020-10-22');

console.log(date1 > date2);
console.log(date1 >= date2);
console.log(date1 < date2);
console.log(date1 <= date2);

輸出:

true
true
false
false
注意
在 JavaScript 中,我們不能直接使用相等運算子來比較 Date 物件。因為在 JavaScript 中,兩個不同的物件在嚴格和抽象的層面上都是不相等的。請看下面的例子。
let date1 = new Date();
let date2 = new Date(date1);

console.log(date1 == date2);
console.log(date1 === date2);
console.log(date1 != date2);
console.log(date1 !== date2);

輸出:

false
false
true
true

我們可以用下面的方法來檢查兩個日期是否相等。

JavaScript 用 getTime() 方法比較兩個日期

我們使用 getTime() 方法將兩個日期轉換成對應於它們的時間的數值,然後我們可以直接比較其中的兩個日期。

let date1 = new Date(2019, 08, 07, 11, 45, 55);
let date2 = new Date(2019, 08, 03, 11, 45, 55);
if (date1.getTime() < date2.getTime())
  document.write('date1 is lesser than date2');
else if (date1.getTime() > date2.getTime())
  document.write('date1 is greater than date2');
else
  document.write('both are equal');

輸出:

date1 is lesser than date2

getTime() 方法可以在 JavaScript 中檢查兩個日期是否相等。

let date1 = new Date();
let date2 = new Date(date1);

if (date1.getTime() == date2.getTime()) document.write('Two dates are equal.');

if (date1.getTime() === date2.getTime()) document.write('Two dates are equal.');

輸出:

Two dates are equal.Two dates are equal.

JavaScript 使用 valueOf() 方法比較兩個日期

Date 物件的 valueOf() 方法與 getTime() 方法類似。它將 Date 物件轉換為數值。

let date1 = new Date(2019, 08, 07, 11, 45, 55);
let date2 = new Date(2019, 08, 07, 11, 45, 55);
if (date1.valueOf() < date2.valueOf())
  document.write('date1 is lesser than date2');
else if (date1.valueOf() > date2.valueOf())
  document.write('date1 is greater than date2');
else if (date1.valueOf() === date2.valueOf())
  document.write('both are equal');

console.log(date1.valueOf() === date2.valueOf())

getTime()valueOf() 都返回自 1970 年 1 月 1 日 00:00 UTC 以來的毫秒數。

JavaScript 使用 Number() 函式比較兩個日期

Number() 函式將日期物件轉換為代表該物件在 Java 中價值的數字。如果物件不能被轉換為一個合法的數字,它將返回 NaN。

let date1 = new Date(2019, 08, 07, 11, 45, 55);
let date2 = new Date(2019, 08, 07, 11, 45, 55);

console.log(Number(date1) === Number(date2))
console.log(Number(date1) == Number(date2))
console.log(Number(date1) < Number(date2))
console.log(Number(date1) > Number(date2))

JavaScript 用一元運算子 + 比較兩個日期

一元運算子接受一個引數,並對這個引數或運算元進行操作。JavaScript 有很多單調運算子。在這裡,我們使用一元加+ 運算子,它試圖將引數轉換為一個數字。

let date1 = new Date(2019, 08, 07, 11, 45, 55);
let date2 = new Date(2019, 08, 07, 11, 45, 55);

console.log(+date1 === +date2)
console.log(+date1 == +date2)
console.log(+date1 < +date2)
console.log(+date1 > +date2)

Number 函式和一元 + 運算子都會在後臺呼叫 valueOf() 方法。

相關文章 - JavaScript DateTime