【问题标题】:Convert Object to Array - maintain named keys将对象转换为数组 - 维护命名键
【发布时间】:2017-06-20 07:58:33
【问题描述】:

我正在将一个对象转换为一个数组。对象的键包含诸如“cool”之类的名称,如下所示:

var obj = {
  "cool": "Mustang",
  "family": "Station Wagon",
  "small": {
    0: "small car 1",
    1: "small car 2"
  }
};

转换时返回的数组如下:

Array[3]
0:"Mustang"
1:"Station Wagon"
2:Object
    0:"small car 1" 
    1:"small car 2"

正如您在上面的数组中看到的那样,对象中的键名(例如“cool”)丢失了,取而代之的是数字。此外,数组包含一个对象,我希望这个对象是数组中的一个数组。

我希望返回的数组是这样的:

Array[3]
"cool":"Mustang"
"family":"Station Wagon"
"small": Array[2]
    0:"small car 1" 
    1:"small car 2"

非常感谢您的帮助。可以在这里找到代码:https://jsfiddle.net/v02q4sy2/8/

var obj = {"cool":"Mustang","family":"Station Wagon","small":{0:"small car 1",1:"small car 2"}}

var arr = $.map(obj, function(value, index) {
    return [value];
});

console.log(arr);

【问题讨论】:

  • 你能告诉我们为什么你想要这个吗?这绝对是不是数组的用途。但这就是绝对对象的用途。
  • 你误解了数组是什么。它的键是索引。
  • 内部对象的预期结果是什么?

标签: javascript jquery arrays json stringify


【解决方案1】:

根据您提供的代码,您似乎只需要在包含相应键/值对的 map 方法中返回一个对象:

Updated Example

var arr = $.map(obj, function(value, key) {
  return { [key]: value };
});

不过,您不需要 jQuery。这是一个简单的示例,使用纯 JavaScript 使用 native .map() methodObject.keys() 从对象中检索可映射的键数组:

Updated Example

var arr = Object.keys(obj).map(function (key) {
  return { [key]: obj[key] };
});

【讨论】:

  • @juanpscotto - 这是动态设置对象的键/值对的一种方法。如果括号[key] 没有像key: obj[key] 那样使用,那么键将是字符串'key',而不是传递的任何动态键值。
  • 这并没有给出他想要的结果。它返回对象,他想要数组。
【解决方案2】:

如果您处于可以使用最新 JavaScript 功能的环境中,使用 Object.entries 就很容易了。

var obj = {"cool":"Mustang","family":"Station Wagon","small":{0:"small car 1",1:"small car 2"}}

var arr = Object.entries(obj);

console.log(arr);

https://jsfiddle.net/eszfLj17/1/

Object.entries()

【讨论】:

  • 这并没有给出他想要的结果。
猜你喜欢
  • 2017-07-14
  • 2021-10-14
  • 1970-01-01
  • 2021-12-28
  • 2016-11-28
  • 2012-11-14
  • 1970-01-01
  • 2020-11-10
相关资源
最近更新 更多