我有一个对象数组,我希望将其转换为简单的Immutable地图:
name: {
urlname
id
}
目前我正在做以下data
作为对象数组:
data = data.map((data) => ({
name: data.name,
urlName: data.urlName,
id: data.id
}))
我想要改变的是以下(data
):
[{"id":"10","name":"Dave","urlName":"foo-bar","order":"-100","classId":"12","className":"David","classUrlName":"david-foo-bar"}]
如上所述,我希望将名称作为键,并将urlName和id作为键的值(如果可能)。我希望循环数据,直到所有内容都缩小到该结构,如果可能的话。
答案 0 :(得分:6)
由于您希望将数据从形状转换为形状,因此您可以使用reduce function来完成此项工作。
reduce
函数会将数据转换为Map
,其中每个键都是name
,值为id
和urlName
const sample = [{"id":"10","name":"Dave","urlName":"foo-bar","order":"-100","classId":"12","className":"David","classUrlName":"david-foo-bar"}];
const result = sample.reduce((acc, item) => {
return acc.set(item.name, {
id: item.id,
urlName: item.urlName,
})
}, new Immutable.Map())
console.log("Dave's Id", result.getIn(["Dave", "id"]));
console.log("Date's urlName", result.getIn(["Dave", "urlName"]));
<script src="https://cdnjs.cloudflare.com/ajax/libs/immutable/4.0.0-rc.9/immutable.js"></script>
查看此处的文档,了解ImmutableJS Reduce和原生Javascript Array.reduce。两者的API都相同。