I'm stuck how i sum two object like this:
obj1 = {
'over_due_data': 10,
'text_data': 5
}
obj2 = {
'over_due_data': 20,
'text_data': 5
}
I went this output
obj = {
'over_due_data': 30,
'text_data': 10
}
One more thing, don't use a for
loop, merge and extend. Is it possible to sum two objects?
try with simply use Object.keys()
and Array#map()
function
obj1 = { 'over_due_data': 10, 'text_data': 5 } obj2 = { 'over_due_data': 20, 'text_data': 5 } var obj ={} Object.keys(obj1).forEach(function(a){ obj[a] = obj1[a] +obj2[a] }) console.log(obj)
Another possible solution, using Array#reduce
.
var obj1 = {'over_due_data':10,'text_data':5}, obj2 = {'over_due_data':20,'text_data':5}, obj = Object.keys(obj1).reduce(function(s,a) { s[a] = obj1[a] + obj2[a]; return s; }, {}) console.log(obj);
Try something like this if you don't want to use loop
obj1 = { 'over_due_data': 10, 'text_data': 5 } obj2 = { 'over_due_data': 20, 'text_data': 5 } var obj = {}; obj['over_due_data'] = obj1['over_due_data'] + obj2['over_due_data'] obj['text_data'] = obj1['text_data'] + obj2['text_data'] console.log(obj)
you can code it dynamically :
var resultObject={};
Object.keys(obj1).forEach(function(objectKey, index) {
resultObject[objectKey]= obj1 [objectKey]+obj2[objectKey];
});
I have used below snippet to sum the two objects even if any of them has additional properties.
This solution is based on Array.prototype.reduce and short-circuit evaluation
Object.keys({ ...obj1, ...obj2 }).reduce((accumulator, currentValue) => {
accumulator[currentValue] =
(obj1[currentValue] || 0) + (obj2[currentValue] || 0);
return accumulator;
}, {});
var obj1 = { 'over_due_data': 10, 'text_data': 5, 'some_add_prop': 80 }; var obj2 = { 'over_due_data': 20, 'text_data': 5, 'add_prop': 100 }; const sumOfObjs = Object.keys({ ...obj1, ...obj2 }).reduce((accumulator, currentValue) => { accumulator[currentValue] = (obj1[currentValue] || 0) + (obj2[currentValue] || 0); return accumulator; }, {}); console.log(sumOfObjs);
This question already have a lot of goods answers but I make a version who also handle multi-levels objects:
let sumAllKeys = (obj1, obj2) => Object.keys({...obj1, ...obj2}).reduce((acc, key) => { let key1 = obj1 && obj1[key] || 0; let key2 = obj2 && obj2[key] || 0; acc[key] = (typeof key1 == "object" || typeof key2 == "object") ? sumAllKeys(key1, key2) : (parseFloat(key1) || 0) + (parseFloat(key2) || 0); return acc; }, {}); // Example: let a = {qwerty:1, azerty: {foo:2, bar:3}} let b = {qwerty:5, azerty: {foo:4}, test:{yes:12, no:13}}; let c = {azerty: {bar:2}, test:{no:1}, another:{child:{subchild:3}}}; console.log("Sum of: ", {a,b,c}); console.log("Equal: ", [a, b, c].reduce(sumAllKeys, {}));
Try this might be helpful
obj1 = { 'over_due_data': 10, 'text_data': 5 } obj2 = { 'over_due_data': 20, 'text_data': 5 } var obj ={} Object.keys(obj1).map(function(a){ obj[a] = obj1[a] +obj2[a] }) console.log(obj)
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.