3 回答

TA貢獻(xiàn)1891條經(jīng)驗(yàn) 獲得超3個(gè)贊
您可以首先使用計(jì)算每個(gè)對(duì)象的總和,map然后reduce使用方法對(duì)該新數(shù)組進(jìn)行排序,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)

TA貢獻(xiàn)1790條經(jīng)驗(yàn) 獲得超9個(gè)贊
您可以先將總和累加到 aMap
中,其中每個(gè)鍵是id
對(duì)象的,每個(gè)值是該對(duì)象tally
數(shù)組的總和。您可以使用.reduce()
來計(jì)算總和。這里acc
是一個(gè)累積值,它從 0 開始,并在每次調(diào)用 reduce 回調(diào)時(shí)被添加。
獲得每個(gè)對(duì)象的總和后,您可以使用.sort()
如下方式根據(jù)每個(gè)對(duì)象的總和進(jìn)行排序:
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);

TA貢獻(xiàn)1828條經(jīng)驗(yàn) 獲得超3個(gè)贊
你可以這樣做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);
添加回答
舉報(bào)