首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对象对象到对象数组

对象对象到对象数组
EN

Stack Overflow用户
提问于 2022-09-20 16:27:05
回答 3查看 34关注 0票数 0

我有这样的对象:

代码语言:javascript
复制
        const testik = {
        0: {
            name: "(REJ) - Rejected",
            value: 'rejected'
        },
        1: {
            name: "(VISA) - Received visa",
            value: 'received_visa'
        }
    }

我想要像这样的最终对象数组:

代码语言:javascript
复制
        const crossingStatusItems = [
        {
            id: '0',
            name: "(REJ) - Rejected",
            value: 'rejected'
        },
        {
            id: '1',
            name: "(VISA) - Received visa",
            value: 'received_visa'
        }]

谢谢你的帮助!

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2022-09-20 16:34:33

Object.entries(testik)将返回对象中键值对的数组。它们可以很容易地被映射到一个新对象数组中,这需要借助spread操作符:

代码语言:javascript
复制
Object.entries(testik).map(([id, v]) => ({...v, id}))

代码语言:javascript
复制
const testik = {
  0: {
    name: "(REJ) - Rejected",
    value: 'rejected'
  },
  1: {
    name: "(VISA) - Received visa",
    value: 'received_visa'
  }
}
const mapped = Object.entries(testik).map(([id, v]) => ({ ...v,
  id
}))
console.log(mapped)

票数 3
EN

Stack Overflow用户

发布于 2022-09-20 16:31:52

尝尝这个

代码语言:javascript
复制
function toArray(obj) {
  return Object.keys(obj).map(function (key) {
    return {
      id: `${key}`,
      ...obj[key],
    };
  });
}

const testik = {
  0: {
    name: "(REJ) - Rejected",
    value: "rejected",
  },
  1: {
    name: "(VISA) - Received visa",
    value: "received_visa",
  },
};

const crossingStatusItems = toArray(testik);
console.log(crossingStatusItems);
票数 0
EN

Stack Overflow用户

发布于 2022-09-20 16:40:42

其中一种方法是使用Object.entries方法,如下所示:

代码语言:javascript
复制
function toArray(obj) {
    return Object.entries(obj).map(function ([id, value]) {
        return {
            ...value,
            id: id,
        };
    });
}

或者更短的版本:

代码语言:javascript
复制
function toArray(obj) {
    return Object.entries(obj).map(([id, value]) => ({ ...value, id }));
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73789852

复制
相关文章

相似问题

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