Tôi có một mảng với các địa chỉ học sinh và phụ huynh.
Ví dụ,
const users = [{
id: 1,
name: 'John',
email: 'johnson@mail.com',
age: 25,
parent_address: 'USA',
relationship:'mother'
},
{
id: 1,
name: 'John',
email: 'johnson@mail.com',
age: 25,
parent_address: 'Spain',
relationship:'father'
},
{
id: 2,
name: 'Mark',
email: 'mark@mail.com',
age: 28,
parent_address: 'France',
relationship:'father'
}
];
Tôi đang cố gắng định dạng lại kết quả này.
const list = [
{
id: 1,
name: 'John',
email: 'johnson@mail.com',
age: 25,
parent: [
{
parent_address: 'USA',
relationship:'mother'
},{
parent_address: 'Spain',
relationship:'father'
}
]
},
{
id: 2,
name: 'Mark',
email: 'mark@mail.com',
age: 28,
parent:[
{
parent_address: 'France',
relationship:'father'
}
]
}
];
Cho đến nay tôi đã thử cách sau. Tôi không chắc đó có phải là cách đúng hay không.
const duplicateInfo = [];
for (var i = 0; i < user[0].length; i++) {
var parent = [];
if (duplicateInfo.indexOf(user[0][i].id) != -1) {
// Do duplicate stuff
} else {
// Do other
}
duplicateInfo.push(user[0][i].id);
}
const list = []
lúc đầu, nhưng ở phía dưới, bạn lặp lại danh sách đó rõ ràng bằng cách lặp lại user[0]
. Mã ví dụ của bạn phải nhất quán.
parent_address
vàrelationship
nhập vào mộtparent
đối tượng và hợp nhất chúng khi tìm thấy tên và địa chỉ email trùng lặp.