JavaScript 数组分组与按日期排序详解

javascript 数组分组与按日期排序详解

本文详细介绍了如何使用 JavaScript 对包含日期和分组信息的对象数组进行分组和排序。通过自定义 groupBy 函数实现按指定属性分组,并结合 sort 方法按日期进行排序,最终将分组后的数组扁平化,得到符合要求的排序结果。本文提供清晰的代码示例和详细的步骤说明,帮助开发者高效地处理类似的数据结构。

问题背景

在实际开发中,经常会遇到需要对数据进行分组和排序的场景。例如,有一组包含日期和分组信息的对象数组,需要按照分组属性进行分组,并在每个分组内按照日期进行排序。本文将介绍如何使用 JavaScript 实现这一功能。

实现步骤

实现该功能的关键在于两个步骤:

分组: 按照指定的属性将数组元素进行分组。排序: 在每个分组内,按照日期进行排序。扁平化: 将分组后的数据转化为一维数组。

下面将详细介绍每个步骤的实现方法。

立即学习“Java免费学习笔记(深入)”;

1. 分组函数 groupBy

首先,我们需要创建一个 groupBy 函数,该函数接收一个数组和一个用于分组的键作为参数。该函数使用 reduce 方法遍历数组,并根据指定的键将元素分组到不同的数组中。

function groupBy(input, key) {    return input.reduce((acc, el) => {         acc[el[key]] = acc[el[key]] || [];        acc[el[key]].push(el);        return acc;    }, {});}

该函数的工作原理如下:

input: 要分组的数组。key: 用于分组的键(属性名)。acc: 累加器,初始值为空对象 {}。el: 当前遍历的数组元素。

在 reduce 方法的回调函数中,首先检查累加器 acc 中是否已存在以当前元素的 key 属性值为键的属性。如果不存在,则创建一个新的空数组;如果存在,则将当前元素添加到该数组中。最后,返回累加器 acc。

2. 排序

在进行分组之前,我们需要先对数组按照日期进行排序,确保最新的元素在前面。这可以通过使用 sort 方法来实现。

const inputSortedByDate = input.sort((a,b) => Date.parse(b.date) - Date.parse(a.date));

sort 方法接收一个比较函数作为参数。该比较函数接收两个数组元素 a 和 b 作为参数,并返回一个数字,指示它们的相对顺序。如果返回值为负数,则 a 排在 b 之前;如果返回值为正数,则 a 排在 b 之后;如果返回值为 0,则 a 和 b 的顺序不变。

在本例中,我们使用 Date.parse 方法将日期字符串转换为时间戳,然后比较两个时间戳的大小。b.date – a.date 确保最新的日期排在前面。

3. 扁平化

分组后,我们需要将结果进行扁平化,也就是将分组后的对象中的值(数组)提取出来,并将它们合并成一个数组。这可以通过 Object.values() 和 Array.flat() 方法来实现。

const grouped = groupBy(inputSortedByDate, 'group');// Get flattened result...const result = Object.values(grouped).flat();

Object.values(grouped) 返回一个包含 grouped 对象所有值的数组。flat() 方法将这个数组扁平化,也就是将所有嵌套的数组元素提取出来,并将它们合并成一个一维数组。

完整代码示例

下面是完整的代码示例:

const input = [  {date: '2023-05-06', group: 'groupA'},  {date: '2023-05-05', group: 'group1'},  {date: '2023-05-07', group: 'groupA'},  {date: '2023-05-08', group: 'group1'},]function groupBy(input, key) {    return input.reduce((acc, el) => {         acc[el[key]] = acc[el[key]] || [];        acc[el[key]].push(el);        return acc;    }, {});}// Group by 'group', but sort first...const inputSortedByDate = input.sort((a,b) => Date.parse(b.date) - Date.parse(a.date));const grouped = groupBy(inputSortedByDate, 'group');// Get flattened result...const result = Object.values(grouped).flat();console.log('Result:', result)

这段代码首先定义了一个包含日期和分组信息的对象数组 input。然后,定义了一个 groupBy 函数,用于按照指定的键对数组进行分组。接着,使用 sort 方法对数组按照日期进行排序。最后,使用 Object.values() 和 flat() 方法将分组后的结果扁平化,并打印到控制台。

总结

本文介绍了如何使用 JavaScript 对包含日期和分组信息的对象数组进行分组和排序。通过自定义 groupBy 函数实现按指定属性分组,并结合 sort 方法按日期进行排序,最终将分组后的数组扁平化,得到符合要求的排序结果。 这种方法可以灵活应用于各种需要对数据进行分组和排序的场景。

注意事项

确保日期字符串的格式能够被 Date.parse 方法正确解析。groupBy 函数可以用于按照任何属性进行分组,只需修改 key 参数即可。如果需要按照多个属性进行排序,可以在 sort 方法中使用更复杂的比较函数。

以上就是JavaScript 数组分组与按日期排序详解的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/118638.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月25日 13:07:12
下一篇 2025年11月25日 13:13:06

相关推荐

  • ALPH是什么币种?ALPH币值得挖吗?

    alephium是layer1上可操作性极强的分片网络,以独特的分片能源效率和可编程性功能而闻名,旨在解决传统区块链可扩展性、安全性等的局限性。alph币是alephium的原生代币,主要作用就是交易、治理、激励等,是alephium生态系统的重要组成部分。对于该项目,投资者不仅好奇alph是什么币…

    2025年12月7日
    000
  • 2025年5月是投资狗狗币的好时机吗?一文解析

    加密货币已成为金融世界中最热门的话题之一,在成千上万的加密货币中,狗狗币(dogecoin)作为最受欢迎和讨论最多的之一脱颖而出。最初作为玩笑而创建的狗狗币,已发展为拥有忠实支持者的社区,且具有自己的生命力。然而,尽管声名显赫,问题仍然存在:狗狗币是否是一项好的投资? 2025年5月是投资狗狗币的好…

    2025年12月7日
    000
  • 在Ethena,Solana Ventures和Rockawayx的支持下,Onre推出了结合现实世界稳定性和链上上升的结构化产物产品

    伦敦,2025年5月21日 /美通社 / – 今天,领先的受监管的链上再保险公司onre推出了一个令牌。一个是累积的令牌 领先的受监管的链再保险公司Onre今天宣布推出它的一个令牌,这是一个积累的有限公司的代币。一个人提供了稳定性和上升空间的无与伦比的组合,并带有独特的现实用例,可能会有…

    2025年12月7日
    000
  • 周三的20年债券拍卖会引发了迅速的市场反应,国库产量急剧上升

    周三的20年债券拍卖会引发了迅速的市场反应,国库产量急剧上升,而几个高增长和技术名称却崩溃了 周三的20年债券拍卖会引发了迅速的市场反应,财政部收益迅速的收益率迅速引起了市场反应,在美国东部时间中止1:05 pm至2:05 pm之间,几个高增长和技术名称突破 – 确切的窗口30年的收益率…

    2025年12月7日
    000
  • BlockDag(BDAG)在20个交流清单之前将价格冻结为$ 0.0020

    加密观察者正在密切跟踪当年最爆炸性的比赛。 bonk最近下降后正在关注恢复,而xrp徘徊在不确定性中。 加密观察者正在密切跟踪当年最爆炸性的比赛。 Bonk最近下降后正在关注恢复,而XRP徘徊在不确定性中。但是,它是Blockdag(BDAG),它以大胆的0.0020价格冻结,并计划宣布20个主要的…

    2025年12月7日
    000
  • REDMI K90系列正式发布,售价2599元起!

    10月23日,redmi k90系列正式亮相,推出redmi k90与redmi k90 pro max两款新机。其中,redmi k90搭载骁龙8至尊版处理器、7100mah大电池及100w有线快充等多项旗舰配置,起售价为2599元,官方称其为k系列迄今为止最完整的标准版本。 图源:REDMI红米…

    2025年12月6日 行业动态
    200
  • 「世纪传奇刀片新篇」飞利浦影音双11声宴开启

    百年声学基因碰撞前沿科技,一场有关声音美学与设计美学的影音狂欢已悄然引爆2025“双十一”! 当绝大多数影音数码品牌还在价格战中挣扎时,飞利浦影音已然开启了一场跨越百年的“声”活革命。作为拥有深厚技术底蕴的音频巨头,飞利浦影音及配件此次“双十一”精准聚焦“传承经典”与“设计美学”两大核心,为热爱生活…

    2025年12月6日 行业动态
    000
  • Vue.js应用中配置环境变量:灵活管理后端通信地址

    在%ignore_a_1%应用中,灵活配置后端api地址等参数是开发与部署的关键。本文将详细介绍两种主要的环境变量配置方法:推荐使用的`.env`文件,以及通过`cross-env`库在命令行中设置环境变量。通过这些方法,开发者可以轻松实现开发、测试、生产等不同环境下配置的动态切换,提高应用的可维护…

    2025年12月6日 web前端
    000
  • VSCode选择范围提供者实现

    Selection Range Provider是VSCode中用于实现层级化代码选择的API,通过注册provideSelectionRanges方法,按光标位置从内到外逐层扩展选择范围,如从变量名扩展至函数体;需结合AST解析构建准确的SelectionRange链式结构以提升选择智能性。 在 …

    2025年12月6日 开发工具
    000
  • JavaScript动态生成日历式水平日期布局的优化实践

    本教程将指导如何使用javascript高效、正确地动态生成html表格中的日历式水平日期布局。重点解决直接操作`innerhtml`时遇到的标签闭合问题,通过数组构建html字符串来避免浏览器解析错误,并利用事件委托机制优化动态生成元素的事件处理,确保生成结构清晰、功能完善的日期展示。 在前端开发…

    2025年12月6日 web前端
    000
  • JavaScript响应式编程与Observable

    Observable是响应式编程中处理异步数据流的核心概念,它允许随时间推移发出多个值,支持订阅、操作符链式调用及统一错误处理,广泛应用于事件监听、状态管理和复杂异步逻辑,提升代码可维护性与可读性。 响应式编程是一种面向数据流和变化传播的编程范式。在前端开发中,尤其面对复杂的用户交互和异步操作时,J…

    2025年12月6日 web前端
    000
  • JavaScript生成器与迭代器协议实现

    生成器和迭代器基于统一协议实现惰性求值与数据遍历,通过next()方法返回{value, done}对象,生成器函数简化了迭代器创建过程,提升处理大数据序列的效率与代码可读性。 JavaScript中的生成器(Generator)和迭代器(Iterator)是处理数据序列的重要机制,尤其在处理惰性求…

    2025年12月6日 web前端
    000
  • VSCode入门:基础配置与插件推荐

    刚用VSCode,别急着装一堆东西。先把基础设好,再按需求加插件,效率高还不卡。核心就三步:界面顺手、主题舒服、功能够用。 设置中文和常用界面 打开软件,左边活动栏有五个图标,点最下面那个“扩展”。搜索“Chinese”,装上官方出的“Chinese (Simplified) Language Pa…

    2025年12月6日 开发工具
    000
  • VSCode性能分析与瓶颈诊断技术

    首先通过资源监控定位异常进程,再利用开发者工具分析性能瓶颈,结合禁用扩展、优化语言服务器配置及项目设置,可有效解决VSCode卡顿问题。 VSCode作为主流的代码编辑器,虽然轻量高效,但在处理大型项目或配置复杂扩展时可能出现卡顿、响应延迟等问题。要解决这些性能问题,需要系统性地进行性能分析与瓶颈诊…

    2025年12月6日 开发工具
    000
  • php查询代码怎么写_php数据库查询语句编写技巧与实例

    在PHP中进行数据库查询,最常用的方式是使用MySQLi或PDO扩展连接MySQL数据库。下面介绍基本的查询代码写法、编写技巧以及实用示例,帮助你高效安全地操作数据库。 1. 使用MySQLi进行查询(面向对象方式) 这是较为推荐的方式,适合大多数中小型项目。 // 创建连接$host = ‘loc…

    2025年12月6日 后端开发
    000
  • VSCode的悬浮提示信息可以自定义吗?

    可以通过JSDoc、docstring和扩展插件自定义VSCode悬浮提示内容,如1. 添加JSDoc或Python docstring增强信息;2. 调整hover延迟与粘性等显示行为;3. 使用支持自定义提示的扩展或开发hover provider实现深度定制,但无法直接修改HTML结构或手动编…

    2025年12月6日 开发工具
    000
  • php数据库如何实现数据缓存 php数据库减少查询压力的方案

    答案:PHP结合Redis等内存缓存系统可显著提升Web应用性能。通过将用户信息、热门数据等写入内存缓存并设置TTL,先查缓存未命中再查数据库,减少数据库压力;配合OPcache提升脚本执行效率,文件缓存适用于小型项目,数据库缓冲池优化和读写分离进一步提升性能,推荐Redis为主并防范缓存穿透与雪崩…

    2025年12月6日 后端开发
    000
  • 优化PDF中下载链接的URL显示:利用HTML title 属性

    在pdf文档中,当包含下载链接时,完整的url路径通常会在鼠标悬停时或直接显示在链接文本中,这可能不符合预期。本文将探讨为何传统方法如`.htaccess`重写或javascript不适用于pdf环境,并提出一种利用html “ 标签的 `title` 属性来定制链接悬停显示文本的解决方…

    2025年12月6日 后端开发
    000
  • Linux命令行中free命令的使用方法

    free命令用于查看Linux内存使用情况,包括总内存、已用、空闲、共享、缓存及可用内存;使用-h可读格式显示,-s周期刷新,-c限制次数,-t显示总计,帮助快速评估系统内存状态。 free命令用于显示Linux系统中内存和交换空间的使用情况,包括物理内存、已用内存、空闲内存以及缓存和缓冲区的占用情…

    2025年12月6日 运维
    000
  • Phaser 3 游戏画布响应式适配:保持高度控制宽度

    本文旨在提供一种在 Phaser 3 游戏中实现画布响应式适配的方案,核心思路是利用 `Phaser.Scale.HEIGHT_CONTROLS_WIDTH` 缩放模式,使画布高度适应父容器,宽度随之调整,并始终居中显示。这种方法适用于需要保持游戏核心内容在屏幕中央,允许左右裁剪的场景。 在 Pha…

    2025年12月6日 web前端
    000

发表回复

登录后才能评论
关注微信