javascript - 格式化对象数组

标签 javascript

<分区>

我正在尝试将 JSON 响应格式化为新格式。

实现预期结果的最佳方法是什么。

JSON 响应

{
  body: [{
    id: 0,
    data: [{
        cellId: 0,
        colId: 'A',
        value: '*',
      },
      {
        cellId: 1,
        colId: 'B',
        value: 'W',
      },
      {
        cellId: 2,
        colId: 'C',
        value: 'ECE',
      }
    ],
    errors: [
      { colId: 'B', errorCode: 'msg_000' },
      { colId: 'D', errorCode: 'msg_001' }
    ]
  }]
}

转换后的预期格式为

const convertedData = {
  id: 0,
  A: '*',
  B: 'W',
  C: 'ECE'
  errors: [
    { colId: 'B', errorCode: 'msg_000' }, 
    { colId: 'D', errorCode: 'msg_001' }
  ]
}

最佳答案

试试这个!!

let obj = {
body: [
    {
      id: 0,
      data: [
        {
          cellId: 0,
          colId: 'A',
          value: '*',
        },
        {
          cellId: 1,
          colId: 'B',
          value: 'W',
        },
        {
          cellId: 2,
          colId: 'C',
          value: 'ECE',
        }
      ],
       errors: [
        {colId: 'B', errorCode: 'msg_000'},
        {colId: 'D', errorCode: 'msg_001'}
       ]
    }
]
};

let resultArr = [];

obj.body.forEach(data=>{
  let newObj = {};
  newObj['id'] = data.id;
  data.data.map(value=>{newObj[value.colId] = value.value});
  newObj['errors'] = data.errors;
  resultArr.push(newObj)
});

console.log(resultArr)

关于javascript - 格式化对象数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58831663/

相关文章:

javascript - Puppeteer Execution 上下文被破坏,很可能是因为导航

javascript - Fabricjs - 如何检测存在对象的 Canvas 的总宽度/高度

javascript - 样式化的媒体接收器源 (Chromecast)

javascript - 获取提供旧数据的变量

javascript - 如何获取与 DOM 元素关联的事件?

javascript - 如何在css和jquery之间切换

javascript - Bash 编码错误

javascript - 用于构造函数的 Q.nfcall 或 Q.denodeify

javascript - 使用 underscore.js 从数组中删除多个项目?

javascript - 如何在不链接到所有其他 Assets 的多个页面中捆绑 Webpack Assets ?