我有一个如下所示的数组。
const arr = [{
  name: 'x',
  type: 'type1',
  parent: [{
    name: "a",
    type: 'type1'
  }]
}, {
  name: 'y',
  type: 'type1',
  parent: [{
    name: "b",
    type: 'type1'
  }]
}];我想把它压平,最后得到如下结果:
const arr = [{
  name: 'x',
  type: 'type1',
  parent-name:'a',
  parent-type: 'type1'
  },
  {
  name: 'y',
  type: 'type1',
  parent-name: 'b',
  parent-type: 'type1'
}];我使用map和array.prototype.flat()尝试过各种不同的解决方案,但无法安静地让它工作。我将永远不会有超过一个孩子,如果有第二个孩子,那么我很好,它创建了2行由此。
谢谢迈克尔
发布于 2019-09-09 01:40:23
一种方法是使用地图()。
result = arr.map(obj => {
  obj.parent.forEach(item => {
    Object.keys(item).forEach(value => {
     obj["parent-" + value] = item[value];
    });
  });
  delete obj.parent;
  return obj;
});实况示例:
const arr = [{
  name: 'x',
  type: 'type1',
  parent: [{
    name: "a",
    type: 'type1'
  }]
}, {
  name: 'y',
  type: 'type1',
  parent: [{
    name: "b",
    type: 'type1'
  }]
}]
result = arr.map(obj => {
  obj.parent.forEach(item => {
    Object.keys(item).forEach(value => {
     obj["parent-" + value] = item[value];
    });
  });
  
  delete obj.parent;
  
  return obj;
});
console.log(result);
https://stackoverflow.com/questions/57846754
复制相似问题