-
万千封印
您可以首先使用计算每个对象的总和,map然后reduce使用方法对该新数组进行排序,sort然后使用另一种map方法删除 sum 属性const array = [{ id: 4, tally: [1, 3, 5] }, { id: 6, tally: [2, 3, 6] }, { id: 9, tally: [2, 1, -1] }]const sorted = array .map(({ tally, ...rest }) => ({ sum: tally.reduce((r, e) => r + e, 0), tally, ...rest })) .sort((a, b) => b.sum - a.sum) .map(({ sum, ...rest }) => rest)console.log(sorted)
-
富国沪深
您可以先将总和累加到 aMap中,其中每个键是id对象的,每个值是该对象tally数组的总和。您可以使用.reduce()来计算总和。这里acc是一个累积值,它从 0 开始,并在每次调用 reduce 回调时被添加。获得每个对象的总和后,您可以使用.sort()如下方式根据每个对象的总和进行排序:const array = [{ id: 4, tally: [1, 3, 5] }, { id: 6, tally: [2, 3, 6] }, { id: 9, tally: [2, 1, -1] }];const sumMap = new Map(array.map( ({id, tally}) => [id, tally.reduce((acc, n) => acc+n, 0)]));const res = array.sort((a, b) => sumMap.get(b.id) - sumMap.get(a.id));console.log(res);
-
子衿沉夜
你可以这样做sort:var arr=[{id:4, tally: [1, 3, 5]}, {id: 6, tally: [2, 3, 6]}, {id: 9, tally: [2, 1, -1]}]var result =arr.sort((a,b)=>{ aa = a.tally.reduce((acc,elem)=>acc+elem,0); bb = b.tally.reduce((acc,elem)=>acc+elem,0); return bb-aa;});console.log(result);