迹忆客 专注技术分享

当前位置:主页 > 学无止境 > WEB前端 > JavaScript >

如何在 JavaScript 中比较两个日期

作者:迹忆客 最近更新:2023/03/24 浏览次数:

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
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() 方法。

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

在 Angular 中上传文件

发布时间:2023/04/14 浏览次数:71 分类:Angular

本教程演示了如何在 Angular 中上传任何文件。我们还将介绍如何在文件上传时显示进度条,并在上传完成时显示文件上传完成消息。

Angular 2 中的复选框双向数据绑定

发布时间:2023/04/14 浏览次数:139 分类:Angular

本教程演示了如何一键标记两个复选框。这篇有 Angular 的文章将着眼于执行复选框双向数据绑定的不同方法。

在 AngularJs 中加载 spinner

发布时间:2023/04/14 浏览次数:107 分类:Angular

我们将介绍如何在请求加载时添加加载 spinner,并在 AngularJs 中加载数据时停止加载器。

在 Angular 中显示和隐藏

发布时间:2023/04/14 浏览次数:78 分类:Angular

本教程演示了 Angular 中的显示和隐藏。在开发商业应用程序时,我们需要根据用户角色或条件隐藏一些数据。我们必须根据该应用程序中的条件显示相同的数据。

在 Angular 中下载文件

发布时间:2023/04/14 浏览次数:104 分类:Angular

本教程演示了如何在 angular 中下载文件。我们将介绍如何通过单击按钮在 Angular 中下载文件并显示一个示例。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便