Object.groupBy分组方法

本文介绍了JavaScript中Array.prototype.groupBy方法,一种用于根据回调函数返回的字符串对可迭代对象元素进行分组的实用工具。由于浏览器兼容性考虑,现以静态方法实现,通过实例展示了如何使用该方法对inventory对象按类型进行分组。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在某些浏览器的某些版本中,此方法被实现为 Array.prototype.group() 方法。由于 web 兼容性问题,它现在以静态方法实现。

函数功能

提供的回调函数返回的字符串值对给定可迭代对象中的元素进行分组。返回的对象具有每个组的单独属性,其中包含组中的元素的数组。

语法

items为可迭代对象
cb为函数接受当前迭代元素和索引,返回一个字符串,groupBy函数将根据这个字符串进行分类

Object.groupBy(items, cb)

示例

    const inventory = [
      { name: "芦笋", type: "蔬菜", quantity: 5 },
      { name: "香蕉", type: "水果", quantity: 0 },
      { name: "山羊", type: "肉", quantity: 23 },
      { name: "樱桃", type: "水果", quantity: 5 },
      { name: "鱼", type: "肉", quantity: 22 },
    ];
    const res = Object.groupBy(inventory, {type}=>type)
    console.dir(res)
    /*
Object
水果: (2) [{…}, {…}]
肉: (2) [{…}, {…}]
蔬菜: [{…}]
	*/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

鲤余

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值