如何在 JavaScript 中按日期对对象数组进行排序

boyanx5个月前技术教程12

如果我们有一个 JavaScript 对象数组,每个对象都包含一个 Date 类型的属性,例如:

const events = [
  { name: 'Birthday', date: new Date('2022-04-23') },
  { name: 'Shopping', date: new Date('2022-04-17') },
  { name: 'Meeting', date: new Date('2022-04-27') },
];

我们如何按日期属性对这些对象进行排序?


数组 sort() 方法

我们可以使用 Array sort() 方法轻松地做到这一点:

events.sort((a, b) => a.date.getTime() - b.date.getTime());

sort 方法将回调函数作为参数。 它使用从此函数返回的值来决定对值进行排序的顺序。

如果回调结果是否定的,则 a 排在 b 之前。

如果结果为正,则 b 排在 a 之前。

如果结果为 0,则两个值的排序顺序保持不变。

这意味着我们可以像这样轻松地按降序对数组进行排序:

events.sort((a, b) => b.date.getTime() - a.date.getTime());


现在,当 b 大于 a 时,结果将是肯定的,这将使 sort() 将 b 放在第一位。


笔记

您还可以通过直接减去 Date 对象来对数组进行排序:

events.sort((a, b) => b.date - a.date);


虽然此方法也有效,但它比使用 getTime() 减法要慢得多。

我们通过单独的 for 循环执行 100 万次,对这两种方法进行了性能比较。 这些是平均结果:

Direct subtraction: 488.675ms
Subtraction with getTime(): 196.909ms


无变异排序

sort() 方法对数组进行就地排序,这意味着它被修改了。 为了防止这种情况,我们可以使用 slice() 方法为排序创建数组的副本:

const sortedEvents = events.slice().sort((a, b) => a.date - b.date);
标签: date.js

相关文章

分享 JavaScript 2024 的 6 个新功能

JavaScript 在2024 年更新引入了 6个关键功能。从使文本和日期更易于处理,到程序等待和协同工作的新方法,甚至使模式更容易查找。我们一起来看看吧!01、格式正确的 Unicode 字符串格...

Linux History命令:如何显示命令执行的日期和时间

在Linux系统中,history命令是一个简单却强大的工具,它允许用户查看和重用之前执行过的命令。然而,默认情况下,history命令的输出仅显示命令的序号和内容,并不包含命令执行的日期和时间。这对...

Mock.js 实用教程:快速上手模拟数据生成

在本篇文章中,我们将深入探讨 Mock.js,(Mock.js 实例:快速入门)这是一款在前端开发中广泛应用的工具库,专门用于生成模拟数据和拦截 Ajax 请求。本文将从以下几个角度展开讨论 Mock...

Moment.js停止更新!Day.js 才是王者!

大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!前言近年来,前端开发人员开始寻找 Mome...

图表控件JavaScript Charts v3.20.0发布

JavaScript Charts能满足大部分的开发需求,包括序列图表(列型图,条形图,线型图,面积图,步骤折线图,平滑折线图,蜡烛图,ohlc图),饼图/环形图,雷达图/极区图以及xy图/散点图/气...

明查|俄罗斯3月11日正式和世界互联网断开链接?

明查员 胡甄卿 陈蕾速览-近日,网传消息称,俄罗斯3月11日正式和世界互联网断网。在3月11日前,俄罗斯服务器和网域将被迁至俄罗斯本地。-白俄罗斯媒体NEXTA披露的俄罗斯政府文件并未明确称,俄罗斯将...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。