我有一个像这样的数组:
var test_array = [
{
"test_name":"vna",
"header_region":"vna_results",
"header_name":"larm",
"value_title":"area"},
{
"test_name":"vna",
"header_region":"vna_results",
"header_name":"larm",
"value_title":"area"},
{
"test_name":"lma",
"header_region":"lma_results",
"header_name":"larm",
"value_title":"area"},
{
"test_name":"lma",
"header_region":"lma_results",
"header_name":"larm",
"value_title":"area"},
{
"test_name":"uni",
"header_region":"uni_results",
"header_name":"larm",
"value_title":"area"},
{
"test_name":"uni",
"header_region":"uni_results",
"header_name":"larm",
"value_title":"area"}
]我想根据属性value:header_name将其分成多个对象
{
"vna_results":[
{
"test_name":"vna",
"header_region":"vna_results",
"header_name":"larm",
"value_title":"area"
},
{
"test_name":"vna",
"header_region":"vna_results",
"header_name":"larm",
"value_title":"area"
}
],
"lma_results":[
{
"test_name":"vna",
"header_region":"lma_results",
"header_name":"larm",
"value_title":"area"
},
{
"test_name":"vna",
"header_region":"lma_results",
"header_name":"larm",
"value_title":"area"
}
],
"uni_results":[
{
"test_name":"vna",
"header_region":"uni_results",
"header_name":"larm",
"value_title":"area"
},
{
"test_name":"vna",
"header_region":"uni_results",
"header_name":"larm",
"value_title":"area"
}
]
}我使用下面的函数来实现这一点:
function groupBy(arr, property) {
return arr.reduce(function(memo, x) {
if (!memo[x[property]]) { memo[x[property]] = []; }
memo[x[property]].push(x);
return memo;
}, {});
}
var splitted = groupBy(test_array, 'header_region');
but the output result changed the order of keys: lma_results first then uni and then vna..
lmi_results:{...},
uni_results:{...},
vna_results:{...},
expected order- same as in array
i don't want to change the order. how to achieve this. Thanks in advance.发布于 2020-03-09 18:38:53
var test_array = [{
"test_name": "vna",
"header_region": "vna_results",
"header_name": "larm",
"value_title": "area"
},
{
"test_name": "vna",
"header_region": "vna_results",
"header_name": "larm",
"value_title": "area"
},
{
"test_name": "lma",
"header_region": "lma_results",
"header_name": "larm",
"value_title": "area"
},
{
"test_name": "lma",
"header_region": "lma_results",
"header_name": "larm",
"value_title": "area"
},
{
"test_name": "uni",
"header_region": "uni_results",
"header_name": "larm",
"value_title": "area"
},
{
"test_name": "uni",
"header_region": "uni_results",
"header_name": "larm",
"value_title": "area"
}
]
const result = test_array.reduce((acc, x) => ({
...acc,
[x.header_region]: [...(acc[x.header_region] || []), x]
}), {});
console.log(result)
https://stackoverflow.com/questions/60598718
复制相似问题