Объединить массив с объектом, используя lodash - PullRequest
0 голосов
/ 06 декабря 2018

Я пытаюсь манипулировать этим образцом массива объектов.

var data = [
  { id: 'A1', name: 'Test', gender: 0, pet: 'dog', petname: 'huahua' },
  { id: 'A1', name: 'Test', gender: 0, pet: 'cat', petname: 'meo' },
  { id: 'A1', name: 'Test', gender: 0, pet: 'snake', petname: 'snakke' },
  { id: 'A1', name: 'Test', gender: 0, pet: 'lion', petname: 'growww' },
];

Что мне нужно сделать, это объединить массив в один объект, подобный этому

var data = [
  {
    id: 'A1', name: 'Test', gender: 0, pet: [
      { type: 'dog', petname: 'huahua' },
      { type: 'cat', petname: 'meo' },
      { type: 'snake', petname: 'snakke' },
      { type: 'lion', petname: 'growww' },
    ]
  },
];

Что такоеСамый простой способ сделать это, используя lodash?Пожалуйста, помогите мне.

Ответы [ 2 ]

0 голосов
/ 06 декабря 2018

Вы можете сделать это кратко через Array.reduce и ES6 destructuring:

var data= [ { id: 'A1', name: 'Test', gender: 0, pet: 'dog', petname: 'huahua'}, { id: 'A1', name: 'Test', gender: 0, pet: 'cat', petname: 'meo'}, { id: 'A1', name: 'Test', gender: 0, pet: 'snake', petname: 'snakke'}, { id: 'A1', name: 'Test', gender: 0, pet: 'lion', petname: 'growww'}, ];

const result = data.reduce((r, {id, name, gender, pet, petname}, i, a) => {
  r.pet.push({ type: pet, petname})
  return i == a.length-1 ? {id, name, gender, pet: r.pet} : r
}, { pet: []})

console.log(result)
0 голосов
/ 06 декабря 2018

Никаких библиотек не нужно, просто используйте сокращение.

var data= [
  { id: 'A1', name: 'Test', gender: 0, pet: 'dog', petname: 'huahua'},
  { id: 'A1', name: 'Test', gender: 0, pet: 'cat', petname: 'meo'},
  { id: 'A1', name: 'Test', gender: 0, pet: 'snake', petname: 'snakke'},
  { id: 'A1', name: 'Test', gender: 0, pet: 'lion', petname: 'growww'}
];

const results = data.reduce((results, current) => {
  const owner = results.find(o => o.id === current.id);
  if (owner) {
    owner.pet.push({ type: current.pet, petname: current.petname });
  } else {
    results.push({id: current.id, name: current.name, gender: current.gender, pet: [{ type: current.pet, petname: current.petname }]});
  }
  return results;
}, []);

console.log(results);
...