你要来点儿小草莓么 2022-07-07 19:47 采纳率: 50%
浏览 16
已结题

json数组格式转换

[{name: '省级校验不合规', value: 0, type: 'top_1'},
{name: '行政处罚修复', value: 100000, type: 'top_1'},
{name: '浙江迟报', value: 200, type: 'top_1'},
{name: '新行政处罚', value: 0, type: 'top_1'},
{name: '国家校验不合规', value: 0, type: 'top_1'},
{name: '省级校验不合规', value: 100, type: 'top_2'},
{name: '新行政许可', value: 200000, type: 'top_2'},
{name: '国家校验不合规', value: 500, type: 'top_2'},
{name: '浙江迟报', value: 0, type: 'top_2'}]

[{name: '省级校验不合规', number1: 0, number2: 100},
{name: '行政处罚修复', number1: 100000, number2: 0},
{name: '浙江迟报', number1: 200, number2: 0},
{name: '新行政处罚', number1: 0, number2: 0},
{name: '国家校验不合规',number1: 0, number2: 500},
{name: '新行政许可', number1: 2000, number2: 0}]

上面的数组想变成下面的数组怎么变啊 求帮一下

  • 写回答

2条回答 默认 最新

  • Heerey525 前端领域新星创作者 2022-07-07 23:54
    关注
    <!DOCTYPE html>
    <html lang="en">
      <head>
        <meta charset="UTF-8" />
        <meta http-equiv="X-UA-Compatible" content="IE=edge" />
        <meta name="viewport" content="width=device-width, initial-scale=1.0" />
        <title>登录页</title>
      </head>
    
      <body>
        <script>
          const arr = [
            { name: "省级校验不合规", value: 0, type: "top_1" },
            { name: "行政处罚修复", value: 100000, type: "top_1" },
            { name: "浙江迟报", value: 200, type: "top_1" },
            { name: "新行政处罚", value: 0, type: "top_1" },
            { name: "国家校验不合规", value: 0, type: "top_1" },
            { name: "省级校验不合规", value: 100, type: "top_2" },
            { name: "新行政许可", value: 200000, type: "top_2" },
            { name: "国家校验不合规", value: 500, type: "top_2" },
            { name: "浙江迟报", value: 0, type: "top_2" },
          ];
          let result = [];
          arr.map((item) => {
            const isFindIndex = result.findIndex(
              (child) => child.name === item.name
            );
            let num = item.type.split("_");
            num = num[1];
            num = "number" + num;
            if (isFindIndex > -1) {
              result[isFindIndex][num] = item.value;
            } else {
              const newObj = { name: item.name, number1: 0, number2: 0 };
              newObj[num] = item.value;
              result.push(newObj);
            }
          });
    
          console.log("result", result);
        </script>
      </body>
    </html>
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 7月16日
  • 已采纳回答 7月8日
  • 创建了问题 7月7日

悬赏问题

  • ¥50 关于#html5#的问题:H5页面用户手机返回的时候跳转到指定页面例如(语言-javascript)
  • ¥15 无法使用此凭据登录,因为你的域不可用,如何解决?(标签-Windows)
  • ¥15 yolov9的训练时间
  • ¥15 二叉树遍历没有报错但无法正常运行
  • ¥15 在linux系统下vscode运行robocup3d上场球员报错
  • ¥15 Python语言实验
  • ¥15 SAP HANA SQL 增加合计行
  • ¥20 用C#语言解决一个英文打字练习器,有偿
  • ¥15 srs-sip外部服务 webrtc支持H265格式
  • ¥15 在使用abaqus软件中,继承到assembly里的surfaces怎么使用python批量调动