将每个对象的元素推入另一个数组中的每个对象

时间:2019-03-15 23:21:49

标签: javascript

我有两个数组,一个是我的原始数组,称为data,由:

const datas = [
  {
    name: 'core Test',
    item: [
      {
        name: 'test/core/core.js',
        item: "item1"
      }
    ]
  },
  {
    name: 'users Test',
    item: [
      {
        name: 'test/users/user.js',
        item: "item2"
      }
    ]
  }
]

我还有一个名为replace的数组,我正在尝试将其每个元素都推入我原来的数组中,即

const replace = [
  {
    type: "test1",
    number: "1",
  },
  {
    type: "test2",
    number: "2",
  }
]

这是我的代码:

const transformedData = datas.map(data => {
  data.item = data.item.map(x => ({
    name: x.name,
    type: replace.map(y=>{return y;})
  }))
  return data
})

我得到的输出:

[
  {
    "name": "core Test",
    "item": [
      {
        "name": "test/core/core.js",
        "type": [
          { "type": "test1", "number": "1" },
          { "type": "test2", "number": "2" }
        ]
      }
    ]
  },
  {
    "name": "users Test",
    "item": [
      {
        "name": "test/users/user.js",
        "type": [
          { "type": "test1", "number": "1" },
          { "type": "test2", "number": "2" }
        ]
      }
    ]
  }
]

我想要的输出:

[
  {
    "name": "core Test",
    "item": [
      {
        "name": "test/core/core.js",
        "type": { "type": "test1", "number": "1" }
      }
    ]
  },
  {
    "name": "users Test",
    "item": [
      {
        "name": "test/users/user.js",
        "type": { "type": "test2", "number": "2" }
      }
    ]
  }
]

1 个答案:

答案 0 :(得分:3)

这是因为您每次都在数据内部的值中时,每次都会遍历整个replace数组。相反,您想跟踪原始地图的索引,因此每次只能有一个实例。

尝试类似的东西:

const transformedData = datas.map((data, index) => {
  data.item = data.item.map(x => ({
    name: x.name,
    type: replace[index]
  }))
  return data;
});