JavaScript-扁平化嵌套对象数组

时间:2018-08-24 22:35:41

标签: javascript object

我正在处理对象数组,需要使用对象值作为新的对象键来展平并将数据集重新分配为单个对象数组。

传入数据:

results = [
  {
    surveyValues: [
      { id: 135, name: 'First Name', value: 'Jim' },
      { id: 136, name: 'Last Name', value: 'Jones' },
      { id: 137, name: 'City', value: 'Fredsburg' },
    ],
  },
  {
    surveyValues: [
      { id: 135, name: 'First Name', value: 'Greg' },
      { id: 136, name: 'Last Name', value: 'Jones' },
      { id: 137, name: 'City', value: 'Waverly' },
    ],
  },
];

所需结果:

output = [
  {
    id: 1, FirstName: 'Jim', LastName: 'Jones', City: 'Fredsburg',
  },
  {
    id: 2, FirstName: 'Greg', LastName: 'Jones', City: 'Waverly',
  },
];

我目前的尝试使我能够以正确的顺序放置更新的键/值对,但创建了大量的单个对象。

当前代码:

const results = [];

surveyResults.map(s => s.surveyValues)
  .forEach(s => Object.entries(s)
  .forEach(([key, value]) => {
    Object.entries(value)
      .forEach(([k, v]) => {
        if (k === 'name') {
          results.push({
            id: value.id,
            [v]: value.value.toString(),
          });
        }
    });
}));

当前代码输出:

[
  {
    id: 135, FirstName: 'Jim',
  },
  {
    id: 136, LastName: 'Jones',
  },
  {
    id: 137, City: 'Fredsburg',
  },
  {
    id: 135, FirstName: 'Greg',
  },
  {
    id: 136, LastName: 'Jones',
  },
  {
    id: 137, City: 'Waverly',
  },
]

我缺少什么?为什么我的代码没有按需要创建新的对象数组?

2 个答案:

答案 0 :(得分:2)

您可以使用mapreduce完成此操作。我还在地图函数的回调函数中访问索引i来设置id属性,并访问string.replace()以从FirstNameLastName键中删除空格。

const results = [
  {
    surveyValues: [
      { id: 135, name: 'First Name', value: 'Jim' },
      { id: 136, name: 'Last Name', value: 'Jones' },
      { id: 137, name: 'City', value: 'Fredsburg' },
    ],
  },
  {
    surveyValues: [
      { id: 135, name: 'First Name', value: 'Greg' },
      { id: 136, name: 'Last Name', value: 'Jones' },
      { id: 137, name: 'City', value: 'Waverly' },
    ],
  },
];


const result = results.map((e, i) => 
  e.surveyValues.reduce((a, e) => {
    a[e.name.replace(" ", "")] = e.value;
    return a;
  }, {id: i + 1})
);

console.log(result);

答案 1 :(得分:0)

在外部map()循环中创建每个对象,并在内部forEach()中向其添加属性。

surveyResults = [
  {
    surveyValues: [
      { id: 135, name: 'First Name', value: 'Jim' },
      { id: 136, name: 'Last Name', value: 'Jones' },
      { id: 137, name: 'City', value: 'Fredsburg' },
    ],
  },
  {
    surveyValues: [
      { id: 135, name: 'First Name', value: 'Greg' },
      { id: 136, name: 'Last Name', value: 'Jones' },
      { id: 137, name: 'City', value: 'Waverly' },
    ],
  },
];

const results = surveyResults.map((s, i) => {
  let v = s.surveyValues;
  let obj = {id: i};
  v.forEach(item => obj[item.name.replace(/\s+/g, "")] = item.value.toString());
  return obj;
});

console.log(results);