如何将数组中 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 值。
以上就是如何合并数组中ID相同的数据,并按type类型分别生成jine属性?的详细内容,更多请关注php中文网其它相关文章!
版权声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系 yyfuon@163.com