将对象数组转换为Map Immutable.js

时间:2017-11-23 17:22:39

标签: javascript reactjs immutable.js

我有一个对象数组,我希望将其转换为简单的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作为键的值(如果可能)。我希望循环数据,直到所有内容都缩小到该结构,如果可能的话。

1 个答案:

答案 0 :(得分:6)

由于您希望将数据从形状转换为形状,因此您可以使用reduce function来完成此项工作。

reduce函数会将数据转换为Map,其中每个键都是name,值为idurlName

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都相同。