php中文网

如何合并数组中ID相同的数据,并按type类型分别生成jine属性?

php中文网

如何将数组中 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 
  }))

解释:

  1. 使用 object.groupby() 函数将数组按 id 分组。该函数返回一个对象,其键为 id 值,值为具有该 id 的数组。
  2. 使用 object.entries() 函数将分组后的对象转换为一个数组,其中每个元素是一个键值对。
  3. 使用 map() 函数遍历键值对数组,并为每个键值对创建一个新对象。
  4. 新对象包含一个 id 属性,以及三个 jine 属性(jine1、jine2 和 jine3),分别对应 早餐、中餐 和 晚餐 类型。
  5. 使用 find() 函数在每个 type 数组中查找与给定 type 匹配的元素,并获取其 jine 值。

以上就是如何合并数组中ID相同的数据,并按type类型分别生成jine属性?的详细内容,更多请关注php中文网其它相关文章!