[ JS ] Как объединить объекты?

LH
На сайте с 26.09.2013
Offline
89
707

// Создаем массив:

let arr = [];

// Помещаем несколько объектов:

arr.push({
div: {
el: '',
style: {}
},
image: {
el: '',
path: ''
}
});

arr.push({
image: {
class: ''
}
});

arr.push({
div: {
el: 'string',
style: {
display: 'block'
}
}
});

// Как на выходе получить 1 объект с объединенными свойствами

// и если свойство уже есть - перезаписать его

// если свойства нет - добавить как новое

{
div: {
el: 'string', // перезаписано
style: { display: 'block' } // добавлено значение
},
image: {
el: '',
path: '',
class: '' // добавлено
}
}
NothingMatters
На сайте с 12.06.2017
Offline
45
#1

Использовать Object.assign()

Как-то так:

const obj = Object.assign({}, arr[0], arr[1]);
LH
На сайте с 26.09.2013
Offline
89
#2
NothingMatters:
Использовать Object.assign()

Как-то так:
const obj = Object.assign({}, arr[0], arr[1]);

Извиняюсь, но я не правильно "озвучил" вопрос. Ваш метод не подойдет.

Исправил вопрос.

NothingMatters
На сайте с 12.06.2017
Offline
45
#3
Leonid H:
Извиняюсь, но я не правильно "озвучил" вопрос. Ваш метод не подойдет.
Исправил вопрос.

Тогда ответ тут https://stackoverflow.com/questions/27936772/how-to-deep-merge-instead-of-shallow-merge (проверил, решение работает)

Конкретно вот это:

/**
* Simple object check.
* @param item
* @returns {boolean}
*/
export function isObject(item) {
return (item && typeof item === 'object' && !Array.isArray(item));
}

/**
* Deep merge two objects.
* @param target
* @param ...sources
*/
export function mergeDeep(target, ...sources) {
if (!sources.length) return target;
const source = sources.shift();

if (isObject(target) && isObject(source)) {
for (const key in source) {
if (isObject(source[key])) {
if (!target[key]) Object.assign(target, { [key]: {} });
mergeDeep(target[key], source[key]);
} else {
Object.assign(target, { [key]: source[key] });
}
}
}

return mergeDeep(target, ...sources);
}

Авторизуйтесь или зарегистрируйтесь, чтобы оставить комментарий