Объединение нескольких объектов внутри одного и того же массива в один объект

var arrObj = [{a:1, b:2},{c:3, d:4},{e:5, f:6}];

как я могу объединить это в один объект?

//mergedObj = {a:1, b:2, c:3, d:4, e:5, f:6}

Ответ 1

Вы можете использовать Array.prototype.reduce как это

var resultObject = arrObj.reduce(function(result, currentObject) {
    for(var key in currentObject) {
        if (currentObject.hasOwnProperty(key)) {
            result[key] = currentObject[key];
        }
    }
    return result;
}, {});

console.log(resultObject);
# { a: 1, b: 2, c: 3, d: 4, e: 5, f: 6 }

Это решение просто собирает все ключи и их значения в каждом объекте в result, который в итоге возвращается нам как результат.

Эта проверка

if (currentObject.hasOwnProperty(key)) {

необходимо убедиться, что мы не включаем все наследуемые перечисляемые свойства в результат.


Если ваша среда поддерживает Object.assign, то вы можете сделать то же самое кратким образом, как это

const arrObj = [{a: 1, b: 2}, {c: 3, d: 4}, {e: 5, f: 6}];

console.log(arrObj.reduce(function(result, current) {
  return Object.assign(result, current);
}, {}));

// If you prefer arrow functions, you can make it a one-liner ;-)
console.log(arrObj.reduce(((r, c) => Object.assign(r, c)), {}));


// Thanks Spen from the comments. You can use the spread operator with assign
console.log(Object.assign({}, ...arrObj));

Ответ 2

Вы можете использовать reduce для элегантного решения:

arrObj.reduce(function(acc, x) {
    for (var key in x) acc[key] = x[key];
    return acc;
}, {});

Подробнее см. MDN docs для reduce.