以下是一个示例代码,用于将数组按键分组为对象:
function groupArrayByKeys(arr, keys) {
// 创建一个空对象,用于存储分组后的结果
const groupedObj = {};
// 遍历数组
arr.forEach(item => {
// 根据给定的键,获取当前项的键值
const key = item[keys];
// 如果对象中已存在该键,则将当前项添加到对应的数组中
if (groupedObj.hasOwnProperty(key)) {
groupedObj[key].push(item);
} else {
// 如果对象中不存在该键,则创建一个新的数组,并将当前项添加进去
groupedObj[key] = [item];
}
});
return groupedObj;
}
// 示例用法
const arr = [
{ id: 1, name: 'Apple' },
{ id: 2, name: 'Banana' },
{ id: 3, name: 'Apple' },
{ id: 4, name: 'Orange' }
];
const groupedObj = groupArrayByKeys(arr, 'name');
console.log(groupedObj);
// 输出:{ Apple: [ { id: 1, name: 'Apple' }, { id: 3, name: 'Apple' } ], Banana: [ { id: 2, name: 'Banana' } ], Orange: [ { id: 4, name: 'Orange' } ] }
在上述示例中,我们定义了一个名为groupArrayByKeys
的函数,它接收两个参数:一个数组arr
和一个键keys
。该函数会遍历数组中的每一项,并将其按照给定的键值分组为一个对象。最后,函数会返回分组后的对象。
在此示例中,我们使用了forEach
方法来遍历数组中的每一项。我们首先获取每一项的键值,然后检查分组后的对象中是否已经存在该键。如果存在,我们将当前项添加到对应的数组中;如果不存在,我们创建一个新的数组,并将当前项添加进去。最后,我们返回分组后的对象。
上一篇:按键将数组分组