JavaScript で 2つの日付を比較する方法

Kirill Ibrahim 2023年10月12日
  1. JavaScript で比較演算子を使って 2つの日付を比較する
  2. JavaScript の getTime() メソッドで 2つの日付を比較する
  3. JavaScript の valueOf() メソッドで 2つの日付を比較する
  4. JavaScript の Number() 関数で 2つの日付を比較する
  5. JavaScript のプラス単項演算子 + で 2つの日付を比較する
JavaScript で 2つの日付を比較する方法

JavaScript には日付の比較システムが組み込まれているので、比較がとても簡単にできます。

このチュートリアルでは、JavaScript で 2つの日付を比較する方法の異なる方法を紹介します。各方法にはコードの例がありますので、ご自身のマシンで実行することができます。

JavaScript で比較演算子を使って 2つの日付を比較する

JavaScript では、<<=>>= などの比較演算子を使って、2つの日付を直接比較することができます。

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
Warning
等値演算子を使って Date オブジェクトを JavaScript で直接比較することはできません。なぜなら、JavaScript の 2つの異なるオブジェクトは、厳密なレベルでも抽象的なレベルでも決して等しくないからです。以下の例を参照してください。
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

以下のメソッドを使って、2つの日付の等号性を確認することができます。

JavaScript の getTime() メソッドで 2つの日付を比較する

getTime() メソッドを用いて 2つの日付をそれぞれの時刻に対応する数値に変換し、直接比較することができます。

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 で 2つの日付が等しいかどうかを調べることができます。

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.');

出力されているのは、getTime() メソッドです。

Two dates are equal.Two dates are equal.

JavaScript の valueOf() メソッドで 2つの日付を比較する

オブジェクトの DatevalueOf() メソッドは 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 日午前 0 時 00 分(UTC)からのミリ秒数を返します。

JavaScript の Number() 関数で 2つの日付を比較する

関数 Number()Date オブジェクトを 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 のプラス単項演算子 + で 2つの日付を比較する

単項演算子は、1つの引数を取り、この引数またはオペランドに対して演算を行います。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