在 JavaScript 中对一组对象进行分组
本文将演示在 JavaScript 中对对象数组进行分组的最有效方法。
在 JavaScript 中使用 reduce()
对对象数组进行分组
在 JavaScript 中对对象数组进行分组的最有效方法是使用 reduce()
函数。此方法执行每个数组元素的(指定)reducer 函数并生成单个输出值。
例子:
我们有一个包含名称和类别这两个属性的产品列表。
const products = [
{name: 'Mathematics', category: 'Subject'},
{name: 'Cow', category: 'Animal'},
{name: 'Science', category: 'Subject'},
];
在上面的示例中,products
是一个对象数组。
接下来,我们需要执行一个简单的操作。使用产品列表,我们将按类别对产品进行分组。
const groupByCategory = {
Subjects: [
{name: 'Mathematics', category: 'Subjects'},
{name: 'Science', category: 'Subjects'},
],
Animals: [{name: 'Cow', category: 'Animals'}],
};
从产品数组中获取类似数组的 groupByCategory
的常用方法是使用适当的回调函数调用 array.reduce()
方法。
const groupByCategory = products.reduce((group, product) => {
const {category} = product;
group[category] = group[category] ?? [];
group[category].push(product);
return group;
}, {});
输出:
"{
'Subject': [
{
'name': 'Mathematics',
'category': 'Subject'
},
{
'name': 'Science',
'category': 'Subject'
}
],
'Animal': [
{
'name': 'Cow',
'category': 'Animal'
}
]
}"
见演示
products.reduce()
函数将数组缩减为按类别分组的产品对象。
array.groupBy
(回调)接受使用三个参数调用的回调函数:当前数组元素、索引和数组本身。回调必须返回一个字符串(你要向其添加功能的组名)。
const groupedObject = array.groupBy((item, index, array) => {
...return groupNameAsString;
});
相关文章
在 JavaScript 中跟踪鼠标位置
发布时间:2024/03/16 浏览次数:188 分类:JavaScript
-
在本教程中,我们将了解如何在 JavaScript 中使用鼠标事件跟踪鼠标位置。
在 JavaScript 中将 Base64 转换为图像
发布时间:2024/03/16 浏览次数:77 分类:JavaScript
-
将 Base64 字符串转换为图像的最简单方法是调用启动图像构造函数并将 base64 字符串作为图像源的函数。此解决方案需要最少的代码行和努力来获得更好的结果。此外,还有一些复杂的实
使用 JavaScript 将图像转换为 Base64 字符串
发布时间:2024/03/16 浏览次数:144 分类:JavaScript
-
本文将讨论如何通过创建画布并将图像加载到其中,并使用文件读取器方法获取图像的相应字符串,将图像转换为其 base64 字符串表示。
在 JavaScript 中操作图像
发布时间:2024/03/16 浏览次数:175 分类:JavaScript
-
本文将介绍 JavaScript 中的图像处理功能。我们将使用 CamanJS 这是一个 JavaScript 库来操作图像。
在 JavaScript 中交换图像
发布时间:2024/03/16 浏览次数:134 分类:JavaScript
-
本教程展示了如何使用 JavaScript 简单地交换图像。你将学习如何使用不同的方法交换图像,例如使用 onclick、鼠标单击和按钮单击。
使用 JavaScript 将 SVG 转换为 PNG
发布时间:2024/03/16 浏览次数:121 分类:JavaScript
-
本教程教授如何从 SVG 创建 PNG 图像。我们将使用 Canvg JavaScript 库和 toDataURL 方法。