首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对象数组中的es6重命名键

对象数组中的es6重命名键
EN

Stack Overflow用户
提问于 2018-05-10 06:44:05
回答 1查看 9.8K关注 0票数 8

我有一个样本数组

代码语言:javascript
复制
const countries = [
    {"id": 1, "name": "Afghanistan"},
    {"id": 2, "name": "Albania"},
    {"id": 3, "name": "Algeria"},
    {"id": 4, "name": "American Samoa"}
];

如何将密钥从id、name更改为labelvalue,就像在es6中那样?

代码语言:javascript
复制
const countries = [
    {"label": 1, "value": "Afghanistan"},
    {"label": 2, "value": "Albania"},
    {"label": 3, "value": "Algeria"},
    {"label": 4, "value": "American Samoa"}
];
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-10 06:45:38

使用.map将一个数组转换为另一个数组,并为语法干扰最小的参数进行重构:

代码语言:javascript
复制
const countries = [
    {"id": 1, "name": "Afghanistan"},
    {"id": 2, "name": "Albania"},
    {"id": 3, "name": "Algeria"},
    {"id": 4, "name": "American Samoa"}
];
const transformed = countries.map(({ id, name }) => ({ label: id, value: name }));
console.log(transformed);

如果需要,还可以转换为参数本身中的新属性名称:

代码语言:javascript
复制
const countries = [
    {"id": 1, "name": "Afghanistan"},
    {"id": 2, "name": "Albania"},
    {"id": 3, "name": "Algeria"},
    {"id": 4, "name": "American Samoa"}
];
const transformed = countries.map(({ id: label, name: value }) => ({ label, value }));
console.log(transformed);

票数 26
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50267076

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档