nazhuantoupailuozi 2023-05-11 18:17 采纳率: 100%
浏览 36
已结题

js 数组快速 重建成理想数据结构

亲,请教一个问题?


[
    {
      "name": "商户1",
      "list": [
        {
          "chargeOffAmounts": 12,
          "writeOffDate": "2023-02-27"
        },
        {
          "chargeOffAmounts": 2,
          "writeOffDate": "2023-03-06"
        }
      ]
    },
    {
      "name": "商户2",
      "list": [
        {
          "chargeOffAmounts": 1,
          "writeOffDate": "2023-03-05"
        }
      ]
    }
  ]

[
    {
      "name": "商户1",
      "list": [
        {
          "chargeOffAmounts": 12,
          "writeOffDate": "2023-02-27"
        },
        {
          "chargeOffAmounts": 0,
          "writeOffDate": "2023-03-05"
        },
        {
          "chargeOffAmounts": 2,
          "writeOffDate": "2023-03-06"
        }
      ]
    },
    {
      "name": "商户2",
      "list": [
      {
          "chargeOffAmounts": 0,
          "writeOffDate": "2023-02-27"
        },
        {
          "chargeOffAmounts": 1,
          "writeOffDate": "2023-03-05"
        },
        {
          "chargeOffAmounts": 0,
          "writeOffDate": "2023-03-06"
        }
      ]
    }
  ]

怎么把上面的结构改成下面的。

  • 写回答

2条回答 默认 最新

  • 前端黑马小扬 2023-05-12 11:03
    关注

    该答案引用 chatgpt @瞬间的未来式

    <script type="text/javascript">
    let arr = [
      {
        "name": "商户1",
        "list": [
          {
            "chargeOffAmounts": 12,
            "writeOffDate": "2023-02-27"
          },
          {
            "chargeOffAmounts": 2,
            "writeOffDate": "2023-03-06"
          }
        ]
      },
      {
        "name": "商户2",
        "list": [
          {
            "chargeOffAmounts": 1,
            "writeOffDate": "2023-03-05"
          }
        ]
      }
    ];
    
    // 获取所有日期列表
    let dateList = Array.from(new Set(arr.flatMap(item => item.list.map(entry => entry.writeOffDate)))).sort();
    
    // 补全日期和chargeOffAmounts字段
    let newArr = arr.map(item => {
      let newList = [];
      dateList.forEach(date => {
        let entry = item.list.find(obj => obj.writeOffDate === date);
        if (entry) {
          newList.push(entry);
        } else {
          newList.push({
            chargeOffAmounts: 0,
            writeOffDate: date
          });
        }
      });
      return {
        name: item.name,
        list: newList
      };
    });
    
    console.log(newArr);
    </script>
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 5月20日
  • 已采纳回答 5月12日
  • 修改了问题 5月12日
  • 修改了问题 5月12日
  • 展开全部

悬赏问题

  • ¥15 x趋于0时tanx-sinx极限可以拆开算吗
  • ¥500 把面具戴到人脸上,请大家贡献智慧
  • ¥15 任意一个散点图自己下载其js脚本文件并做成独立的案例页面,不要作在线的,要离线状态。
  • ¥15 各位 帮我看看如何写代码,打出来的图形要和如下图呈现的一样,急
  • ¥30 c#打开word开启修订并实时显示批注
  • ¥15 如何解决ldsc的这条报错/index error
  • ¥15 VS2022+WDK驱动开发环境
  • ¥30 关于#java#的问题,请各位专家解答!
  • ¥30 vue+element根据数据循环生成多个table,如何实现最后一列 平均分合并
  • ¥20 pcf8563时钟芯片不启振