首页
学习
活动
专区
工具
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
页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

领券