다음과 같은 두 개의 객체 배열이 있다고 가정합니다. -
const arr1 = [ {name:'test', lastname: 'test', gender:'f'}, {name:'test1', lastname: 'test1', gender:'f'}, {name:'test2', lastname: 'test2', gender:'m'} ]; const arr2 = [ {name:'test21', lastname: 'test21', gender:'f'}, {name:'test1', lastname: 'test1', gender:'f'}, {name:'test2', lastname: 'test2', gender:'m'}, {name:'test22', lastname: 'test22', gender:'m'} ];
이 배열에는 ('name' 속성을 기준으로 반복) 반복되는 개체가 없지만 첫 번째 및 두 번째 개체에 이름이 반복되는 개체가 있습니다.
이러한 두 개의 배열을 사용하여 새 배열을 반환하는 JavaScript 함수를 작성해야 합니다.
새 배열에는 첫 번째와 두 번째 배열의 모든 고유 개체가 포함되어야 합니다. 여기에서 개체의 고유성을 확인하기 위해 개체의 고유한 "이름" 속성을 확인합니다.
예시
이에 대한 코드는 -
const arr1 = [ {name:'test', lastname: 'test', gender:'f'}, {name:'test1', lastname: 'test1', gender:'f'}, {name:'test2', lastname: 'test2', gender:'m'} ]; const arr2 = [ {name:'test21', lastname: 'test21', gender:'f'}, {name:'test1', lastname: 'test1', gender:'f'}, {name:'test2', lastname: 'test2', gender:'m'}, {name:'test22', lastname: 'test22', gender:'m'} ]; const mergeUniquely = (arr1 = [], arr2 = []) => { const newArr = arr1.concat(arr2); const map = {}; const res = []; newArr.forEach(el => { if(!map[el['name']]){ res.push(el); map[el['name']] = 1; }; }); return res; }; console.log(mergeUniquely(arr1, arr2));
출력
콘솔의 출력은 -
[ { name: 'test', lastname: 'test', gender: 'f' }, { name: 'test1', lastname: 'test1', gender: 'f' }, { name: 'test2', lastname: 'test2', gender: 'm' }, { name: 'test21', lastname: 'test21', gender: 'f' }, { name: 'test22', lastname: 'test22', gender: 'm' } ]