javascript - 如何从具有多个键的json对象收集数据并将所有值推送到单个键:value array

标签 javascript json object ecmascript-6 foreach

我有一个示例 json 对象:

var jsonString = '[{ "name":"John", "age":30, "car":Mercedes},{ "name":"Jimy", "age":32, "car":Audi},{ 
"name":"Mia", "age":22, "car":Renault},{ "name":"Frank", "age":35, "car":null }]';

var data = JSON.parse(jsonString);

我想从数据数组中获取最新的两个数据并创建一个键:值数组,以便每个 json 属性在数组中都有一个键,并且所有 json 对象中的所有值都存储在它们的下适当的键,例如,我想要的结果一般是数组 [{key: data_array_for_that_key}] 或具体来说:

output=[{name: [Frank, Mia]}, {age: [35,22]}, {car: [null, Renault]}......]

我尝试过这样的事情:

var output = [];

  data.slice(-2).forEach((d, i) => {
    Object.keys(d).forEach((key) => {
      output.push({[key] : d[key]});
    });
  });
  console.log(output);

但它为每个 json 对象创建一个键和值,这不是我想要的。

我该如何解决这个问题?

最佳答案

您可以采用哈希表来分组相同的键,并为每个新键推送一个新对象以输出

var jsonString = '[{ "name":"John", "age":30, "car":"Mercedes"},{ "name":"Jimy", "age":32, "car":"Audi"},{"name": "Mia", "age": 22, "car": "Renault"},{"name": "Frank","age": 35,"car": null}]',
    data = JSON.parse(jsonString);
    output = [],
    temp = [];

data.slice(-2).forEach(o => Object.entries(o).forEach(([k, v]) => {
    if (!temp[k]) output.push({ [k]: temp[k] = [] });
    temp[k].push(v);
}));

console.log(output);
.as-console-wrapper { max-height: 100% !important; top: 0; }

关于javascript - 如何从具有多个键的json对象收集数据并将所有值推送到单个键:value array,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/60064587/

相关文章:

c++:什么时候使用指针?

javascript - 图像轮播波动且未给出预期结果

javascript - 如何在 JSDoc 中引用仓库?

java - Jackson 注册自定义 json 序列化器

android - 在 JSON 对象中处理空值

javascript - 在 Javascript 中使用 PHP Json

javascript - 如何检查包含另一个对象数组的对象数组是否具有属性

c++ - 使用常量变量声明对象数组

javascript - 为什么 Facebook Javascript SDK 是异步加载的?

javascript - 如何从 jQuery 回调中打开新的浏览器选项卡