gpt4 book ai didi

javascript - 使用 Lodash 合并复杂对象数组

转载 作者:行者123 更新时间:2023-11-29 16:47:38 26 4
gpt4 key购买 nike

我是 Lodash 的新手,正在尝试解决这个问题,但我可以找到一个很好的方法来解决这个问题。

我有一组从数据库返回的对象。数据结构如下:

var data = [{
index: 1,
Aoo: "a1",
Boo: 'b2',
}, {
index: 1,
Aoo: "a2",
Boo: 'b2',
}, {
index: 2,
Aoo: "a3",
Boo: 'b3',
}];

我想先按索引对对象进行分组,然后将属性“Aoo”和“Boo”分组,并将其放入名为 param 的数组属性中。

var result = [{
index: 1,
param: [{
Aoo: 'A1',
Boo: 'B1'
},{
Aoo: 'A2',
Boo: 'B2',
}]
}, {
index: 2,
param: [{
Aoo: 'A3',
Boo: 'B3'
}]
}
]

我可以手动完成,但我想充分利用 Lodash 的功能。现在我只知道我可以通过使用 _.groupBy('index') 实现分组的第一步,但我不知道下一步该怎么做。

最佳答案

你快到了。这是如何使用 lodash 完成的

var data = [{
index: 1,
Aoo: "a1",
Boo: 'b2',
}, {
index: 1,
Aoo: "a2",
Boo: 'b2',
}, {
index: 2,
Aoo: "a3",
Boo: 'b3',
}];

var result = _.chain(data)
.groupBy('index')
.map((value, key) => {
return {
index: Number(key), //the index was transformed into a string, this will make it a number again.
param: _.map(value, o => _.omit(o, 'index'))//do not include the index key from the previous objects
}
})
.value();

console.log(result);
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.16.1/lodash.min.js"></script>

诚然,第二部分比分组稍微棘手一些,但幅度不大。由于索引为您提供了这种结构:

{
"1": [
{
"index": 1,
"Aoo": "a1",
"Boo": "b2"
},
{
"index": 1,
"Aoo": "a2",
"Boo": "b2"
}
],
"2": [
{
"index": 2,
"Aoo": "a3",
"Boo": "b3"
}
]
}

您真正想要做的就是检查它,使每个键成为 index 属性,然后您会得到一个初始对象数组。每个都需要通过删除 index 键进行转换,并将其分配给 param 值。这是使用 .map 一次性完成的。不幸的是,它并不像看起来那么漂亮,但我认为这是 Lodash 基本版本所能做的最好的事情。

如果你想选择键的特定子集,而不是“除了index”,那么你可以使用_.pick而不是_ .omit 来做。这是它的样子:

var data = [{
index: 1,
Aoo: "a1",
Boo: 'b2',
Coo: "c1"
}, {
index: 1,
Aoo: "a2",
Boo: 'b2',
Coo: "c2"
}, {
index: 2,
Aoo: "a3",
Boo: 'b3',
Coo: "c3"
}];

var result = _.chain(data)
.groupBy('index')
.map((value, key) => {
return {
index: Number(key), //the index was transformed into a string, this will make it a number again.
param: _.map(value, o => _.pick(o, ['Aoo', 'Boo']))//do not include the index key from the previous objects
}
})
.value();

console.log(result);
<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.16.1/lodash.min.js"></script>

所以即使数据中有一个额外的键,我们也会得到相同的结果。

关于javascript - 使用 Lodash 合并复杂对象数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39604832/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com