登录
首页 >  文章 >  前端

嵌套数组如何快速扁平化处理

时间:2026-01-26 22:09:56 477浏览 收藏

哈喽!今天心血来潮给大家带来了《嵌套数组如何高效扁平化为属性扩展数组》,想必大家应该对文章都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习文章,千万别错过这篇文章~希望能帮助到你!

如何高效地将嵌套对象数组扁平化为属性扩展的数组

本文介绍一种使用 `map` 与对象遍历结合的方式,将含 `items`(子对象数组)的原始对象数组,转换为每个对象直接包含 `productX` 对应值作为键、`quantity` 作为值的新数组。方法简洁、可读性强,且不修改原始数据。

在实际开发中,我们常遇到需要“展开”嵌套结构的场景:原始数据中每个对象的 items 字段是一个对象数组,每个子对象形如 { productOne: "crust", quantity: 2.2 },而目标是将这些键值对动态提升为外层对象的自有属性(如 crust: 2.2),同时移除 items 字段。

以下是一个健壮、可复用的转换函数:

function flattenItems(arr) {
  return arr.map(original => {
    // 浅拷贝原对象,避免副作用
    const result = { ...original };

    // 遍历 items 中每个子项
    for (const item of original.items || []) {
      let key, value;

      // 动态识别非 quantity 字段作为属性名,quantity 值作为属性值
      for (const [k, v] of Object.entries(item)) {
        if (k === 'quantity') {
          value = v;
        } else {
          key = v; // 注意:此处 v 是字符串值(如 "crust"),即新属性名
        }
      }

      // 安全赋值:仅当 key 和 value 均存在时才扩展
      if (key !== undefined && value !== undefined) {
        result[key] = value;
      }
    }

    // 移除 items 字段
    delete result.items;

    return result;
  });
}

使用示例:

const firstArray = [
  {
    amount: 343,
    code: "RCU8YI0NKS",
    items: [
      { productOne: "crust", quantity: 2.2 },
      { productTwo: "dust", quantity: 34 }
    ],
    user_id: "wewewefwOHG22323kj"
  },
  {
    amount: 343,
    code: "RCU8YI0NKS",
    items: [
      { productTwo: "dust", quantity: 32 },
      { productThree: "must", quantity: 34 }
    ],
    user_id: "m2LgLRD9MEVNAX56JTpRYDkOOjd2"
  }
];

console.log(flattenItems(firstArray));
// 输出即为目标格式 secondArray

⚠️ 注意事项:

  • 若某 item 中存在多个非 quantity 字段(如同时有 productOne 和 productTwo),当前逻辑仅取最后一个遍历到的非 quantity 键对应值作为属性名 —— 这符合原始数据结构(每个 item 固定一个产品字段 + 一个 quantity 字段);
  • 建议增加空值防护(如 original.items?.length 判断),尤其在数据可能缺失 items 时;
  • 属性名冲突(如两个 item 的 product 值相同)会导致后写入覆盖前写入,若需合并逻辑(如累加 quantity),需另行扩展;
  • 时间复杂度为 O(n × m)(n 为外层数组长度,m 为平均 items 长度),已是该问题的最优解,无可避免的线性扫描。

该方案兼顾可读性、安全性与扩展性,适用于大多数类似的数据规整需求。

终于介绍完啦!小伙伴们,这篇关于《嵌套数组如何快速扁平化处理》的介绍应该让你收获多多了吧!欢迎大家收藏或分享给更多需要学习的朋友吧~golang学习网公众号也会发布文章相关知识,快来关注吧!

前往漫画官网入口并下载 ➜
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>