javascript - 如何用变量重命名对象的键?

标签 javascript json

我有一个对象:

blocks: [
  {
    type: 'animal',
    data: { text: 'Bark bark' }
  },
  {
    type: 'human',
    data: { text: 'Speak speak' }
  },
  ...
]

data:命名不符合我的需要,我想将其重命名为 type值(value)。所以它应该看起来像这样:

blocks: [
  {
    type: 'animal',
    animal: { text: 'Bark bark' }
  },
  {
    type: 'human',
    human: { text: 'Speak speak' }
  },
  ...
]

如何用很少的 JavaScript 代码实现这一点?我的解决方案确实有效,但似乎很愚蠢(特别是如果您考虑 10 多种不同类型的情况):

const blocks = [];
oldBlocks.map(block => {
    const {type, data} = block;
    blocks.push({
        type: type,
        animal: type === "animal" ? data : undefined,
        human: type === "human" ? data : undefined,
        ....
    });
});

最佳答案

使用方括号表示对象内部的表达式,允许您将变量作为键名称进行计算:

blocks.map(({type, data}) => ({ type, [type]: data }));
<小时/>

示例:

let blocks = [
  {
    type: 'animal',
    data: { text: 'Bark bark' }
  },
  {
    type: 'human',
    data: { text: 'Speak speak' }
  }
],


result = blocks.map(({type, data}) => ({ type, [type]: data }));

console.log(result);

关于javascript - 如何用变量重命名对象的键?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57513740/

相关文章:

javascript - 关于用 JavaScript 定位 DOM 元素的基本问题

javascript - 在 JSON 文件中获取第一级数据时面临问题

javascript - 使用 gulp 在页面上临时添加脚本

javascript - jQuery:如何正确暂停递归?

json - 如何使用 JMESPath 列出对象的属性名称?

javascript - 在 Java 中映射 JSON 对象

c# - 无法使用 Json.net 序列化具有复杂键的字典

c++ - CPPRest SDK 向服务器发出 HTTP 请求

javascript - 无法从模态上的动态输入获取未定义或空引用的属性 'value'

javascript - 如何在对话框中锁定焦点?