Reputation: 61
I have two arrays:
const people = [{id:1, name:"John"}, {id:2, name:"Alice"}];
const address = [{id:1, peopleId: 1, address: "Some street 1"}, {id:2, peopleId: 2, address: "Some street 2"}]
How can I filter over this two arrays and get one like this:
const fullData = [{id: 1, name: "John", address: "Some street 1"}, {id: 2, name: "Alice", address: "Some street 2"}]
Upvotes: 3
Views: 38965
Reputation: 5064
You can use reduce to do that,
const people = [{id:1, name:"John"}, {id:2, name:"Alice"}];
const address = [{id:1, peopleId: 1, address: 'Some street 1'}, {id:2, peopleId: 2, address: 'Some street 2'}]
const res = people.reduce((acc, curr) => {
const index = address.findIndex(item => item.peopleId === curr.id);
if(index > -1) {
curr.address = address[index].address;
}
acc.push(curr);
return acc;
}, []);
console.log(res);
Upvotes: 0
Reputation: 1
How to map two address with peopleId 2
const persons = [{id:1, name: 'John'}, {id:2, name: 'Alice'}]
const addresses = [{id:1, peopleId: 1, address: 'Some street 1'}, {id:2, peopleId: 2, address: 'Some street 2'},{id:3, peopleId: 2, address: 'Some street 3'}]
const result = persons.map(person => {
const addressItem = addresses.find(address => address.peopleId === person.id)
person.address = addressItem
? addressItem.address
: null
return person
})
console.log(result)
Upvotes: 0
Reputation: 37775
You can try this.
With the help of map()
and find()
const people = [{id:1, name:"John"}, {id:2, name:"Alice"}];
const address = [{id:1, peopleId: 1, address: 'Some street 1'}, {id:2, peopleId: 2, address: 'Some street 2'}]
let op = people.map((e,i)=>{
let temp = address.find(element=> element.id === e.id)
if(temp.address) {
e.address = temp.address;
}
return e;
})
console.log(op);
Upvotes: 18
Reputation: 22989
Like this:
const persons = [{id:1, name: 'John'}, {id:2, name: 'Alice'}]
const addresses = [{id:1, peopleId: 1, address: 'Some street 1'}, {id:2, peopleId: 2, address: 'Some street 2'}]
const result = persons.map(person => {
const addressItem = addresses.find(address => address.peopleId === person.id)
person.address = addressItem
? addressItem.address
: null
return person
})
console.log(result)
Upvotes: 4