Введение
В этом лабе мы будем изучать процесс объединения объектов в JavaScript. Лабка проведет вас по шагам создания нового объекта путем объединения двух или более объектов. Вы научитесь использовать Array.prototype.reduce() и Object.keys() для перебора по объектам и ключам, а также Object.prototype.hasOwnProperty() и Array.prototype.concat() для объединения значений для существующих ключей.
Функция объединения объектов
Для объединения двух или более объектов следуйте шагам:
- Откройте Терминал/SSH и введите
node, чтобы начать программирование. - Используйте
Array.prototype.reduce()вместе сObject.keys()для перебора по всем объектам и ключам. - Используйте
Object.prototype.hasOwnProperty()иArray.prototype.concat()для добавления значений для ключей, которые есть в нескольких объектах. - Используйте заданный фрагмент кода для создания нового объекта из объединения двух или более объектов.
const merge = (...objs) =>
[...objs].reduce(
(acc, obj) =>
Object.keys(obj).reduce((a, k) => {
acc[k] = acc.hasOwnProperty(k)
? [].concat(acc[k]).concat(obj[k])
: obj[k];
return acc;
}, {}),
{}
);
Например, рассмотрите следующие объекты:
const object = {
a: [{ x: 2 }, { y: 4 }],
b: 1
};
const other = {
a: { z: 3 },
b: [2, 3],
c: "foo"
};
Когда вы объединяете эти два объекта с использованием функции merge(), вы получаете следующий результат:
merge(object, other);
// { a: [ { x: 2 }, { y: 4 }, { z: 3 } ], b: [ 1, 2, 3 ], c: 'foo' }
Резюме
Поздравляем! Вы завершили лабу по объединению объектов. Вы можете практиковаться в более многих лабах в LabEx, чтобы улучшить свои навыки.