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}
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}
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));
ES5 的解决方案:
你可以像这样使用 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
和apply
来完全避免使用reduce。Object.assign.apply( null, objects );
- SpenObject.assign( ...arrObj )
- Spen你可以使用reduce
实现一种优雅的解决方案:
arrObj.reduce(function(acc, x) {
for (var key in x) acc[key] = x[key];
return acc;
}, {});
Object.assign(...arrObj)
- super cool