以下是一个示例代码,用于按键进行JQ分组,合并值,然后展平对象:
const data = [
{ key: 'A', value: [1, 2, 3] },
{ key: 'B', value: [4, 5, 6] },
{ key: 'A', value: [7, 8, 9] }
];
const result = data.reduce((acc, curr) => {
if (acc[curr.key]) {
acc[curr.key] = acc[curr.key].concat(curr.value);
} else {
acc[curr.key] = curr.value;
}
return acc;
}, {});
const flattenedResult = Object.entries(result).reduce((acc, [key, value]) => {
acc.push({ key, value });
return acc;
}, []);
console.log(flattenedResult);
输出结果为:
[
{ key: 'A', value: [1, 2, 3, 7, 8, 9] },
{ key: 'B', value: [4, 5, 6] }
]
在这个示例中,我们使用了Array.prototype.reduce()
方法来对数据进行分组和合并。首先,我们创建一个空对象result
作为累加器。然后,我们遍历数据数组,如果累加器中已经存在相同的键(curr.key
),则将当前值(curr.value
)追加到已存在的值后面,否则将当前键和值添加到累加器中。最后,我们使用Object.entries()
方法将累加器对象转换为一个键值对数组,并使用Array.prototype.reduce()
方法将其展平为所需的结果数组。
上一篇:按键进入特定进程