以下是一个可以按照JSON键值对对列表进行分组并创建一个新列表的JavaScript代码示例:
// 按照键值对对列表进行分组并创建新列表的函数
function groupBy(jsonList, key) {
const grouped = {};
// 遍历列表中的每个JSON对象
jsonList.forEach((item) => {
const value = item[key];
// 如果键值对不存在,则创建一个新数组
if (!grouped[value]) {
grouped[value] = [];
}
// 将当前JSON对象添加到对应的数组中
grouped[value].push(item);
});
// 将分组后的结果转换为新列表
const newList = Object.keys(grouped).map((value) => {
return {
[key]: value,
items: grouped[value]
};
});
return newList;
}
// 示例使用
const jsonList = [
{ id: 1, category: 'A' },
{ id: 2, category: 'B' },
{ id: 3, category: 'A' },
{ id: 4, category: 'C' },
{ id: 5, category: 'B' }
];
const newList = groupBy(jsonList, 'category');
console.log(newList);
输出结果:
[
{ category: 'A', items: [ { id: 1, category: 'A' }, { id: 3, category: 'A' } ] },
{ category: 'B', items: [ { id: 2, category: 'B' }, { id: 5, category: 'B' } ] },
{ category: 'C', items: [ { id: 4, category: 'C' } ] }
]
这个例子中,我们定义了一个groupBy
函数,它接受一个JSON对象列表和一个键名作为参数。函数首先创建一个空对象grouped
来存储分组后的结果。然后,我们遍历列表中的每个JSON对象,获取指定键名的值。如果该值在grouped
对象中不存在,我们创建一个新数组作为值。然后,将当前JSON对象添加到对应的数组中。最后,我们使用Object.keys
方法将grouped
对象的键转换为一个数组,然后使用map
方法创建一个新的JSON对象数组,每个对象包含键和对应的分组数组。最后,我们返回这个新列表。
在示例中,我们使用了一个包含5个JSON对象的列表,并通过category
键对它们进行分组。最终,我们得到了一个新的列表,其中每个对象都包含一个category
键和对应的分组数组。我们将结果打印到控制台上。