如何解决javascript reduce 使用reduce/map函数将平面数组转换为嵌套数组
[
{"eventId":"84","shootId":"72","clubEventId":"253","clubId":"7"},{"eventId":"84","clubEventId":"254","clubId":"5"},"clubEventId":"255","clubId":"6"},{"eventId":"85","clubEventId":"256","clubEventId":"257","clubEventId":"258","clubId":"6"}
]
我想用一个 reduce 函数优雅地将其转换为具有以下结构:
{
"84" : {
"clubEvents" : {
"253" : {
"clubEventId" : 253,"clubId" : 7 },"254" : {
"clubEventId" : 254,"clubId" : 5 },"255" : {
"clubEventId" : 255,"clubId" : 6}
},"shootId" : 72,},"85" : {
"clubEvents" : {
"253" : {
"clubEventId" : 256,"254" : {
"clubEventId" : 257,"255" : {
"clubEventId" : 258,}
}
如有任何帮助,我将不胜感激。
解决方法
您可以为作业采用两级嵌套。
const
data = [{ eventId: "84",shootId: "72",clubEventId: "253",clubId: "7" },{ eventId: "84",clubEventId: "254",clubId: "5" },clubEventId: "255",clubId: "6" },{ eventId: "85",clubEventId: "256",clubEventId: "257",clubEventId: "258",clubId: "6" }],result = data.reduce((r,{ eventId,shootId,clubEventId,clubId }) => {
r[eventId] ??= { clubEvents: {},shootId };
r[eventId].clubEvents[clubEventId] = { clubEventId,clubId };
return r;
},{});
console.log(result);
.as-console-wrapper { max-height: 100% !important; top: 0; }
使用 reduce
const arr = [
{ eventId: "84",];
const result = arr.reduce((acc,curr) => {
const { eventId,clubId } = curr;
if (!acc[eventId]) {
acc[eventId] = {
clubEvents: {
[clubEventId]: { clubEventId,clubId },},};
} else {
const obj = acc[eventId];
obj["clubEvents"][clubEventId] = { clubEventId,clubId };
}
return acc;
},{});
console.log(result);
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。