normalizr - 如何用于基于 属性 的分组
normalizr -How to use for grouping based on a property
我需要重组来自服务器 API 的数据以在我的客户端应用程序中使用,我开始了解 normalizr。如果可能的话,我正在尝试使用这个库。
数据结构如下
{
"history": [{
"_id": "5a09d7a48134664b58eb9ff7",
"created": "2017-11-13"
}, {
"_id": "5a09d79c8134664b58eb9ff6",
"created": "2017-11-13"
}, {
"_id": "5a09d7968134664b58eb9ff5",
"created": "2017-11-13"
}, {
"_id": "5a0349da81069a3754ac1a91",
"created": "2017-11-08"
}
]
}
我想根据'created'来分组,如下。
{
"history": {
"2017-11-13": [{
"_id": "5a09d7a48134664b58eb9ff7",
"created": "2017-11-13"
}, {
"_id": "5a09d79c8134664b58eb9ff6",
"created": "2017-11-13"
}, {
"_id": "5a09d7968134664b58eb9ff5",
"created": "2017-11-13"
}
],
"2017-11-08": [{
"_id": "5a0349da81069a3754ac1a91",
"created": "2017-11-08"
}
]
}
}
如何使用 normalizr 做到这一点?我知道我需要的只是重组数据,normalizr 是最好的选择吗?
您可以使用 ES6 版本通过以下功能完成此操作
function grouping (arr, key) {
return (arr || []).reduce((acc, x = {}) => ({
...acc,
[x[key]]: [...acc[x[key]] || [], x]
}), {})
}
它有两个参数,数组和分组依据
的键
function grouping (arr, key) {
return (arr || []).reduce((acc, x = {}) => ({
...acc,
[x[key]]: [...acc[x[key]] || [], x]
}), {})
}
let history = [{
"_id": "5a09d7a48134664b58eb9ff7",
"created": "2017-11-13"
}, {
"_id": "5a09d79c8134664b58eb9ff6",
"created": "2017-11-13"
}, {
"_id": "5a09d7968134664b58eb9ff5",
"created": "2017-11-13"
}, {
"_id": "5a0349da81069a3754ac1a91",
"created": "2017-11-08"
}
];
console.log(grouping(history,'created'));
我需要重组来自服务器 API 的数据以在我的客户端应用程序中使用,我开始了解 normalizr。如果可能的话,我正在尝试使用这个库。
数据结构如下
{
"history": [{
"_id": "5a09d7a48134664b58eb9ff7",
"created": "2017-11-13"
}, {
"_id": "5a09d79c8134664b58eb9ff6",
"created": "2017-11-13"
}, {
"_id": "5a09d7968134664b58eb9ff5",
"created": "2017-11-13"
}, {
"_id": "5a0349da81069a3754ac1a91",
"created": "2017-11-08"
}
]
}
我想根据'created'来分组,如下。
{
"history": {
"2017-11-13": [{
"_id": "5a09d7a48134664b58eb9ff7",
"created": "2017-11-13"
}, {
"_id": "5a09d79c8134664b58eb9ff6",
"created": "2017-11-13"
}, {
"_id": "5a09d7968134664b58eb9ff5",
"created": "2017-11-13"
}
],
"2017-11-08": [{
"_id": "5a0349da81069a3754ac1a91",
"created": "2017-11-08"
}
]
}
}
如何使用 normalizr 做到这一点?我知道我需要的只是重组数据,normalizr 是最好的选择吗?
您可以使用 ES6 版本通过以下功能完成此操作
function grouping (arr, key) {
return (arr || []).reduce((acc, x = {}) => ({
...acc,
[x[key]]: [...acc[x[key]] || [], x]
}), {})
}
它有两个参数,数组和分组依据
的键function grouping (arr, key) {
return (arr || []).reduce((acc, x = {}) => ({
...acc,
[x[key]]: [...acc[x[key]] || [], x]
}), {})
}
let history = [{
"_id": "5a09d7a48134664b58eb9ff7",
"created": "2017-11-13"
}, {
"_id": "5a09d79c8134664b58eb9ff6",
"created": "2017-11-13"
}, {
"_id": "5a09d7968134664b58eb9ff5",
"created": "2017-11-13"
}, {
"_id": "5a0349da81069a3754ac1a91",
"created": "2017-11-08"
}
];
console.log(grouping(history,'created'));