javascript - 按不同数组中设置的属性类型分隔项目
问题描述
我正在尝试通过在 restful API 中返回的名为“ProductGroupName”的属性来分隔项目。我想循环并为每个部分创建一个单独的数组,其中每个部分都列为该属性。
我可以在服务器端操纵我的 SQL 来改变结果的给出方式,但这会导致问题;这是一个示例结果:
{
"message": "Success",
"data": [
{
"StockID": 69323,
"TradeName": "NAN OPTIPRO HA 1 GLD 800G",
"ProductGroupName": "BABY FOODS",
"SOH": 24,
"MinimumSOH": 0,
"Retail": 3199,
"AverageRetail": 0,
"Cost": 2848,
"RealCost": 2791,
"Reorder": true,
"Message": null,
"ListCost": null,
"Markup": 12,
"PLU": "476358",
"NoDiscount": true
},
{
"StockID": 18057,
"TradeName": "NAN PRO 2 GLD 800G",
"ProductGroupName": "BABY FOODS",
"SOH": 19,
"MinimumSOH": 0,
"Retail": 2050,
"AverageRetail": 0,
"Cost": 2301,
"RealCost": 1918,
"Reorder": false,
"Message": null,
"ListCost": null,
"Markup": -10,
"PLU": "436178",
"NoDiscount": true
},
{
"StockID": 74206,
"TradeName": "OPTIFAST VLCD SHAKE BANANA 12X53G (NEW)",
"ProductGroupName": "WEIGHT LOSS",
"SOH": 6,
"MinimumSOH": 0,
"Retail": 4799,
"AverageRetail": 0,
"Cost": 3937,
"RealCost": 3086,
"Reorder": true,
"Message": null,
"ListCost": null,
"Markup": 10,
"PLU": "294454",
"NoDiscount": true
}],
}
这是所有结果的标准输出,因此更改结果会使我编写 REST 服务的方式复杂化。
对这些项目进行分组的最佳方式是什么?我正在考虑遍历它们,当找到一个新的“ProductGroup”时,会创建一个新的数组并插入该项目,但这似乎不是很优化,我想知道是否有更好的方法来实现这一点.
解决方案
以您在问题中描述的方式组织请求结果的最简单方法之一是将 Array.prototype.reduce 应用于结果的“数据”:
result.data.reduce((acc, item) => {
const name = item['ProductGroupName'];
acc[name] = acc[name] || [];
acc[name].push(item);
return acc;
}, {});
使用这种方法,您将获得以下对象
{BABY FOODS: Array(2), WEIGHT LOSS: Array(1)}
推荐阅读
- javascript - 当我按下波兰字母如:ó, ł, ą, ż 脚本移动 3 个空格时,应该只移动 1 个空格
- karate - 我正在 JS 中设计一个用于滚动动态页面的函数,如何将文档作为参数传递?
- python - Calculate silhouette score for each object with cluster medoids
- python - TypeError: 尝试使用 df.diff() 时 -: 'str' 和 'str' 不支持的操作数类型
- mysql - MySQL ordering with GROUP BY and ORDER BY different column
- python - TypeError: expected str, bytes or os.PathLike object, not FileStorage 不断弹出
- instagram - Does Instagram Reels have an API for developers?
- python - Flask - Why doesn't this let me import image files?
- delphi - TCalendarPicker not styled (Delphi 10.4)
- gitlab - Can I use CCMenu with Gitlab CI?