Lodash groupBy 嵌套对象数组中每一项的id
Lodash groupBy id of each item of nested array of object
我有以下输入作为 clubs
的示例,其中包括一个 属性 players
,它是一个对象数组。
输入
const clubs = [
{
id: 5,
name: 'Club Name',
creatorId: 10,
players: [
{
userId: 2, // group by this property
name: 'Player name 1',
clubId: 5,
},
{
userId: 7, // group by this property
name: 'Player name 2',
clubId: 5,
},
],
},
{
id: 6,
name: 'Club Name 2',
creatorId: 2,
players: [
{
userId: 7, // group by this property
name: 'Player name 3',
clubId: 6,
},
{
userId: 8, // group by this property
name: 'Player name 4',
clubId: 6,
},
{
userId: 22, // group by this property
name: 'Player name 5',
clubId: 6,
},
],
},
];
我想 groupBy
每个俱乐部的每个 player.userId
并且应该有每个球员的俱乐部价值,以获得以下输出。
期望的输出
{
'2': [{ id: 5, name: 'Club Name', creatorId: 10, players: [Array] }],
'7': [
{ id: 5, name: 'Club Name', creatorId: 10, players: [Array] },
{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] },
],
'8': [{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] }],
'22': [{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] }],
};
我试过了
const byPlayer = allClubs.reduce((b, a) => {
a.players.forEach((player) => {
const id = player.clubId;
const clubsByPlayer = b[id] || (b[id] = []);
clubsByPlayer.push(a);
});
return b;
}, {});
但是它返回了 clubId
的组和俱乐部中每个球员的值
{
'5': [
{ id: 5, name: 'Club Name', creatorId: 10, players: [Array] },
{ id: 5, name: 'Club Name', creatorId: 10, players: [Array] },
],
'6': [
{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] },
{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] },
{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] },
],
};
替换
const id = player.clubId;
与
const id = player.userId;
const
clubs = [{ id: 5, name: 'Club Name', creatorId: 10, players: [{ userId: 2, name: 'Player name 1', clubId: 5 }, { userId: 7, name: 'Player name 2', clubId: 5 }] }, { id: 6, name: 'Club Name 2', creatorId: 2, players: [{ userId: 7, name: 'Player name 3', clubId: 6 }, { userId: 8, name: 'Player name 4', clubId: 6 }, { userId: 22, name: 'Player name 5', clubId: 6 }] }],
byPlayer = clubs.reduce((b, a) => {
a.players.forEach((player) => {
(b[player.userId] ??= []).push(a);
});
return b;
}, {});
console.log(byPlayer)
.as-console-wrapper { max-height: 100% !important; top: 0; }
我有以下输入作为 clubs
的示例,其中包括一个 属性 players
,它是一个对象数组。
输入
const clubs = [
{
id: 5,
name: 'Club Name',
creatorId: 10,
players: [
{
userId: 2, // group by this property
name: 'Player name 1',
clubId: 5,
},
{
userId: 7, // group by this property
name: 'Player name 2',
clubId: 5,
},
],
},
{
id: 6,
name: 'Club Name 2',
creatorId: 2,
players: [
{
userId: 7, // group by this property
name: 'Player name 3',
clubId: 6,
},
{
userId: 8, // group by this property
name: 'Player name 4',
clubId: 6,
},
{
userId: 22, // group by this property
name: 'Player name 5',
clubId: 6,
},
],
},
];
我想 groupBy
每个俱乐部的每个 player.userId
并且应该有每个球员的俱乐部价值,以获得以下输出。
期望的输出
{
'2': [{ id: 5, name: 'Club Name', creatorId: 10, players: [Array] }],
'7': [
{ id: 5, name: 'Club Name', creatorId: 10, players: [Array] },
{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] },
],
'8': [{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] }],
'22': [{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] }],
};
我试过了
const byPlayer = allClubs.reduce((b, a) => {
a.players.forEach((player) => {
const id = player.clubId;
const clubsByPlayer = b[id] || (b[id] = []);
clubsByPlayer.push(a);
});
return b;
}, {});
但是它返回了 clubId
的组和俱乐部中每个球员的值
{
'5': [
{ id: 5, name: 'Club Name', creatorId: 10, players: [Array] },
{ id: 5, name: 'Club Name', creatorId: 10, players: [Array] },
],
'6': [
{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] },
{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] },
{ id: 6, name: 'Club Name 2', creatorId: 2, players: [Array] },
],
};
替换
const id = player.clubId;
与
const id = player.userId;
const
clubs = [{ id: 5, name: 'Club Name', creatorId: 10, players: [{ userId: 2, name: 'Player name 1', clubId: 5 }, { userId: 7, name: 'Player name 2', clubId: 5 }] }, { id: 6, name: 'Club Name 2', creatorId: 2, players: [{ userId: 7, name: 'Player name 3', clubId: 6 }, { userId: 8, name: 'Player name 4', clubId: 6 }, { userId: 22, name: 'Player name 5', clubId: 6 }] }],
byPlayer = clubs.reduce((b, a) => {
a.players.forEach((player) => {
(b[player.userId] ??= []).push(a);
});
return b;
}, {});
console.log(byPlayer)
.as-console-wrapper { max-height: 100% !important; top: 0; }