将具有数组的对象转换为数组

Transform an object with an array into an array

我有以下数据结构:

const data = {
  "firstName": "A",
  "lastName": "B",
  "address": [{
    "country": "France",
    "city": "Paris"
  },
    {
      "country": "Italy",
      "city": "Rome"
    }
  ],
};

我想使用 Ramda 将其转换为:

const result = [
  {
    "firstName": "A",
    "lastName": "B",
    "address": {
      "country": "France",
      "city": "Paris"
    },
  },
  {
    "firstName": "A",
    "lastName": "B",
    "address": {
      "country": "Italy",
      "city": "Rome"
    },
  },
];

1) 创建一个空字典

2) for 循环数组并将字典中每个数组的索引存储为值

我不确定这是否对您有帮助,但如果您想基于 adress 生成多个对象,也许这对您有帮助

const obj = {
  firstName: "a",
  lastName: "b",
  adresses: [{
    country: "France",
    city: "Paris"
  }, {
    country: "Italy",
    city: "Rome"
  }]
};

adressAmount = obj.adresses.length;

const adressObjects = [];

for (let i = 0; i < adressAmount; i++) {
  const {
    adresses,
    ...objWithoutAdresses
  } = obj;
  objWithoutAdresses.adress = obj.adresses[i];
  adressObjects.push(objWithoutAdresses);
}

console.log(adressObjects);

您可以根据需要迭代地址数组并创建对象

let obj = {
  "firstName": "A",
  "lastName": "B",
  "address": [{
      "country": "France",
      "city": "Paris"
    },
    {
      "country": "Italy",
      "city": "Rome"
    }
  ]
}


let newData = obj.address.map(function(item) {

  return {
    firstName: obj.firstName,
    lastName: obj.lastName,
    address: {
      country: item.country,
      city: item.city
    }
  }


});
console.log(newData)

您可以使用 converge 函数分叉道具 address,然后将其与列表中每个地址的主对象连接:

/**
 * R.pick could be replaced with R.omit
 * to let you black list properties:
 * R.omit(['address']); https://ramdajs.com/docs/#omit
**/
const createByAddress = R.converge(R.map, [
  R.pipe(R.pick(['firstName', 'lastName']), R.flip(R.assoc('address'))),
  R.prop('address'),
]);

const data = {
  "firstName": "A",
  "lastName": "B",
  "address": [{
    "country": "France",
    "city": "Paris"
    },
    {
      "country": "Italy",
      "city": "Rome"
    }
  ],
};

console.log(createByAddress(data));
<script src="https://cdnjs.cloudflare.com/ajax/libs/ramda/0.26.1/ramda.js" integrity="sha256-xB25ljGZ7K2VXnq087unEnoVhvTosWWtqXB4tAtZmHU=" crossorigin="anonymous"></script>

我的问题是为什么 "with Ramda"?我是 Ramda 的创始人和忠实粉丝,但它只是一个工具,除非这是 Ramda 的学习练习,否则似乎没有必要使用它来解决这个问题。

我会这样做,使用现代 JS 技术:

const transform = ({address, ...rest}) => 
  address .map (a => ({...rest, address: a}))

const data = {firstName: "A", lastName: "B", address: [{country: "France", city: "Paris"}, {country: "Italy", city: "Rome"}]}

console .log (
  transform (data)
)


请注意您的问题所附的评论。 Whosebug 不是代码编写服务。这里的社区希望您亲自尝试并展示您遇到的问题。

我发现这非常简单和简短。

const data = {
  "firstName": "A",
  "lastName": "B",
  "address": [{
    "country": "France",
    "city": "Paris"
  },
    {
      "country": "Italy",
      "city": "Rome"
    }
  ],
};



let requiredData = data.address.map(element=>{
return {...data,address:element}
})

console.log(requiredData);