
如何将数组中 id 相同的数据合并为对象?
给定一个数组 list,其中每个元素都包含 id、jine 和 type 属性。要求将数组中 id 相同的数据合并为一个对象,新的对象应具有 id 及不同 type 对应的 jine 属性。
原数据:
const list = [
{
id: "202301",
jine: 23,
type: "晚餐"
},
{
id: "202301",
jine: 87.5,
type: "早餐"
},
{
id: "202301",
jine: 1065.5,
type: "中餐"
},
{
id: "202302",
jine: 10,
type: "晚餐"
},
{
id: "202302",
jine: 181.5,
type: "早餐"
},
{
id: "202302",
jine: 633.5,
type: "中餐"
}
];期望数据格式:
const list = [
{
id: "202301",
jine1: 87.5, // 早
jine2: 1065.5, // 中
jine3: 23 // 晚
},
{
id: "202302",
jine1: 181.5, // 早
jine2: 633.5, // 中
jine3: 10 // 晚
}
];解决方案:
Object.entries(Object.groupBy(list, item => item.id))
.map(([k, v]) => ({
id: k,
jine1: v.find(e => e.type === '早餐')?.jine,
jine2: v.find(e => e.type === '中餐')?.jine,
jine3: v.find(e => e.type === '晚餐')?.jine
}))解释:
- 使用 object.groupby() 函数将数组按 id 分组。该函数返回一个对象,其键为 id 值,值为具有该 id 的数组。
- 使用 object.entries() 函数将分组后的对象转换为一个数组,其中每个元素是一个键值对。
- 使用 map() 函数遍历键值对数组,并为每个键值对创建一个新对象。
- 新对象包含一个 id 属性,以及三个 jine 属性(jine1、jine2 和 jine3),分别对应 早餐、中餐 和 晚餐 类型。
- 使用 find() 函数在每个 type 数组中查找与给定 type 匹配的元素,并获取其 jine 值。










