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'));