假设我们有一个像这样的对象数组-
const arr = [ {"firstName":"John", "value": 89}, {"firstName":"Peter", "value": 151}, {"firstName":"Anna", "value": 200}, {"firstName":"Peter", "value": 22}, {"firstName":"Anna","value": 60} ];
我们需要编写一个JavaScript函数,该函数接受一个这样的数组,并将firstName属性具有相似值的所有那些对象的value属性组合在一起。
因此,对于上述数组,输出应类似于-
const output = [ {"firstName":"John", "value": 89}, {"firstName":"Peter", "value": 173}, {"firstName":"Anna", "value": 260} ];
对于每个对象,我们将递归地找到它们的相似对象
(与此问题的上下文相似的对象是具有相似的firstName值的对象)。
然后,我们将value属性添加到一个对象,并从数组中删除另一个对象。这将一直进行到我们到达数组末尾为止。达到目标后,我们会将阵列缩小为所需的阵列。
以下是代码-
const arr = [ {"firstName":"John", "value": 89}, {"firstName":"Peter", "value": 151}, {"firstName":"Anna", "value": 200}, {"firstName":"Peter", "value": 22}, {"firstName":"Anna","value": 60} ]; const sumSimilar = arr => { const res = []; for(let i = 0; i < arr.length; i++){ const ind = res.findIndex(el => el.firstName === arr[i].firstName); if(ind === -1){ res.push(arr[i]); }else{ res[ind].value += arr[i].value; }; }; return res; }; console.log(sumSimilar(arr));
输出结果
这将在控制台中产生以下输出-
[ { firstName: 'John', value: 89 }, { firstName: 'Peter', value: 173 }, { firstName: 'Anna', value: 260 } ]