首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

使用Lodash在对象数组中使用多个groupBy和sumBy

Lodash是一个流行的JavaScript工具库,提供了许多实用的函数来简化开发过程。在对象数组中使用多个groupBy和sumBy可以通过Lodash的groupBy和sumBy函数来实现。

  1. groupBy函数:groupBy函数可以根据指定的属性对对象数组进行分组。它接受两个参数,第一个参数是要分组的数组,第二个参数是一个回调函数,用于指定分组的依据。

示例代码:

代码语言:txt
复制
const _ = require('lodash');

const data = [
  { name: 'Alice', age: 25, gender: 'female' },
  { name: 'Bob', age: 30, gender: 'male' },
  { name: 'Charlie', age: 35, gender: 'male' },
  { name: 'David', age: 40, gender: 'male' },
  { name: 'Eve', age: 45, gender: 'female' }
];

const groupedData = _.groupBy(data, 'gender');
console.log(groupedData);

输出结果:

代码语言:txt
复制
{
  female: [
    { name: 'Alice', age: 25, gender: 'female' },
    { name: 'Eve', age: 45, gender: 'female' }
  ],
  male: [
    { name: 'Bob', age: 30, gender: 'male' },
    { name: 'Charlie', age: 35, gender: 'male' },
    { name: 'David', age: 40, gender: 'male' }
  ]
}
  1. sumBy函数:sumBy函数可以计算对象数组中指定属性的总和。它接受两个参数,第一个参数是要计算总和的数组,第二个参数是一个回调函数,用于指定要计算总和的属性。

示例代码:

代码语言:txt
复制
const _ = require('lodash');

const data = [
  { name: 'Alice', age: 25, gender: 'female' },
  { name: 'Bob', age: 30, gender: 'male' },
  { name: 'Charlie', age: 35, gender: 'male' },
  { name: 'David', age: 40, gender: 'male' },
  { name: 'Eve', age: 45, gender: 'female' }
];

const totalAge = _.sumBy(data, 'age');
console.log(totalAge);

输出结果:

代码语言:txt
复制
175

综合应用: 可以结合groupBy和sumBy函数,实现在对象数组中使用多个groupBy和sumBy的功能。例如,我们可以根据性别分组,并计算每个性别的年龄总和。

示例代码:

代码语言:txt
复制
const _ = require('lodash');

const data = [
  { name: 'Alice', age: 25, gender: 'female' },
  { name: 'Bob', age: 30, gender: 'male' },
  { name: 'Charlie', age: 35, gender: 'male' },
  { name: 'David', age: 40, gender: 'male' },
  { name: 'Eve', age: 45, gender: 'female' }
];

const groupedData = _.groupBy(data, 'gender');
const result = {};

_.forEach(groupedData, (group, key) => {
  result[key] = _.sumBy(group, 'age');
});

console.log(result);

输出结果:

代码语言:txt
复制
{
  female: 70,
  male: 105
}

推荐的腾讯云相关产品和产品介绍链接地址:

  • 腾讯云函数计算(云原生无服务器计算服务):https://cloud.tencent.com/product/scf
  • 腾讯云云数据库 MySQL 版(关系型数据库服务):https://cloud.tencent.com/product/cdb
  • 腾讯云对象存储(分布式文件存储服务):https://cloud.tencent.com/product/cos
  • 腾讯云区块链服务(基于腾讯云的区块链解决方案):https://cloud.tencent.com/product/bcs
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

27分24秒

051.尚硅谷_Flink-状态管理(三)_状态在代码中的定义和使用

13分46秒

16.尚硅谷-IDEA-版本控制在IDEA中的配置和使用.avi

13分46秒

16.尚硅谷-IDEA-版本控制在IDEA中的配置和使用.avi

18分34秒

Vue3.x全家桶 48_在组合API中provide和inject使用 学习猿地

7分8秒

059.go数组的引入

11分33秒

061.go数组的使用场景

7分44秒

087.sync.Map的基本使用

3分0秒

四轴飞行器在ROS、Gazebo和Simulink中的路径跟踪和障碍物规避

6分9秒

054.go创建error的四种方式

1分10秒

Adobe国际认证教程指南|如何在 Premiere Pro 中处理多个项目?

36分12秒

1.尚硅谷全套JAVA教程--基础必备(67.32GB)/尚硅谷Java入门教程,java电子书+Java面试真题(2023新版)/08_授课视频/121-面向对象(高级)-IDEA中快捷键的使用和修改.mp4

1分51秒

Ranorex Studio简介

领券