如何将对象的这个对象转换为对象的数组?

时间:2018-10-13 10:04:17

标签: javascript arrays type-conversion

如何转换该对象:

var json = {
    "user3" : {
        "id" : 1
    },
    "user1" : {
        "id" : 3
    },
    "user2" : {
        "id" : 6
    }
}

此数组:

var json = [{
        "name": "user1",
        "id": 3
    }, {
        "name": "user2",
        "id": 6
    }, {
        "name": "user3",
        "id": 1
    }];

有人可以告诉我吗?或者如何像第一个示例那样对对象进行排序?

4 个答案:

答案 0 :(得分:2)

尝试

const src = {
    "user3" : {
        "id" : 1
    },
    "user1" : {
        "id" : 3
    },
    "user2" : {
        "id" : 6
    }
}

const out = Object.keys(src).map((key) => ({name: key, id: src[key].id}))

答案 1 :(得分:0)

您可以使用Object.keys()Array.prototype.reduce()遍历对象项并从单个项中创建一个数组。

Object.keys(json).reduce((items, username) => {
const user = json[username];
   return items.concat({
      name: username,
      id: user.id
   });
}, []);

答案 2 :(得分:0)

您可以使用Object.entries将对象转换为数组。使用map遍历数组,并使用Object.assign构造新对象。

var json = {
  "user3": {
    "id": 1
  },
  "user1": {
    "id": 3
  },
  "user2": {
    "id": 6
  }
}

var result = Object.entries(json).map(([k, o]) =>Object.assign(o, {name: k}));

console.log(result);

答案 3 :(得分:0)

使用for-in loop的另一种方法:

const json = {
    "user3": {
        "id": 1
    },
    "user1": {
        "id": 3
    },
    "user2": {
        "id": 6
    }
}

const result = [];

for (const prop in json) {
    result.push({ "name": prop, "id": json[prop].id });
}

console.log(result);

将提供:

[ { name: 'user3', id: 1 },
  { name: 'user1', id: 3 },
  { name: 'user2', id: 6 } ]