
本教程旨在指导开发者如何使用 JavaScript 对包含日期和分组信息的对象数组进行分组,并按照日期进行排序。通过groupBy函数实现按指定属性分组,并结合sort方法按照日期降序排列,最终将分组后的数据扁平化,生成符合预期结果的数组。
假设我们有一个包含对象的数组,每个对象都包含 date(日期)和 group(分组)属性。我们的目标是将数组按照 group 属性进行分组,并在每个分组内按照 date 属性进行降序排序,最后将所有分组扁平化为一个新的数组。
实现该功能的关键在于以下几个步骤:
以下是完整的代码示例:
立即学习“Java免费学习笔记(深入)”;
10分钟内自己学会PHP其中,第1篇为入门篇,主要包括了解PHP、PHP开发环境搭建、PHP开发基础、PHP流程控制语句、函数、字符串操作、正则表达式、PHP数组、PHP与Web页面交互、日期和时间等内容;第2篇为提高篇,主要包括MySQL数据库设计、PHP操作MySQL数据库、Cookie和Session、图形图像处理技术、文件和目录处理技术、面向对象、PDO数据库抽象层、程序调试与错误处理、A
524
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);代码解释:
运行以上代码,将会输出以下结果:
Result: [
{ date: '2023-05-08', group: 'group1' },
{ date: '2023-05-05', group: 'group1' },
{ date: '2023-05-07', group: 'groupA' },
{ date: '2023-05-06', group: 'groupA' }
]可以看到,数组已经按照 group 属性进行了分组,并且每个分组内的元素都按照 date 属性进行了降序排序。
通过本教程,我们学习了如何使用 JavaScript 对包含日期和分组信息的对象数组进行分组和排序。 groupBy 函数提供了一种通用的分组方法,可以根据任意属性对数组进行分组。 结合 sort 方法和 flat 方法,我们可以灵活地处理各种数据结构,满足不同的业务需求。
以上就是JavaScript 数组分组与按日期排序教程的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号