如何解决如何找到对象数组中特定键的总和
[
{
_id: 60b18e0a7ba49519c1ee63b4,course: 'sfsdf',earnings: 100,creator: '607497d5f4bcc83fa1f3cedf',month: 1,year: 2019
},{
_id: 60b18e1a7ba49519c1ee63b5,earnings: 200,month: 2,{
_id: 60b18e227ba49519c1ee63b6,earnings: 300,month: 3,{
_id: 60b18e297ba49519c1ee63b7,earnings: 400,month: 4,{
_id: 60b18b907ba49519c1ee63a5,course: 'html-css',earnings: 1000,year: 2021
},{
_id: 60b18c457ba49519c1ee63a9,earnings: 500,year: 2020
}
]
我想以某种方式操作上面的数组,使结果看起来像:
[
{ label: 2019,earnings: 1000 },{ label: 2021,{ label: 2020,earnings: 500 },]
其中 label
是唯一的年份,earnings
是该年所有收入的总和。
问题说明:
-
2019 年有 4 个对象,每年的收益分别为 100、200、300、400,总计为 1000 (100 + 200 + 300 + 400),因此结果数组有 {{1 }}
-
2021 年有 1 个对象,收入为 1000,因此总收入为 1000,因此结果数组有
{ label: 2019,earnings: 1000 }
对于 2020 年也是如此。
解决方法
您可以使用 findIndex
和 forEach
const response = [
{
_id: "60b18e0a7ba49519c1ee63b4",course: 'sfsdf',earnings: 100,creator: '607497d5f4bcc83fa1f3cedf',month: 1,year: 2019
},{
_id: "60b18e1a7ba49519c1ee63b5",earnings: 200,month: 2,{
_id: "60b18e227ba49519c1ee63b6",earnings: 300,month: 3,{
_id: "60b18e297ba49519c1ee63b7",earnings: 400,month: 4,{
_id: "60b18b907ba49519c1ee63a5",course: 'html-css',earnings: 1000,year: 2021
},{
_id: "60b18c457ba49519c1ee63a9",earnings: 500,year: 2020
}
];
const result = [];
response.forEach(({earnings,year}) => {
const index = result.findIndex(({label}) => label === year);
if (index === -1) result.push({label: year,earnings});
else result[index].earnings += earnings;
})
console.log(result)
const result = arr.reduce((acc,obj) => {
const idx = acc.findIndex(o => o.label === obj.year);
if (idx !== -1) acc[idx].earnings += obj.earnings;
else acc.push({ label: obj.year,earnings: obj.earnings });
return acc;
},[])
console.log(result)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。