将对象数组转换为单个对象

Convert array of objects into a single object

例如,我有以下数组 -

[
  {
    name: "abc",
    value: "1"
  },
  {
    name: "xyz",
    value: "2"
  },
  {
    name: "abc",
    value: "3"
  },
  {
    name: "abc",
    value: "4"
  },
  {
    name: "xyz",
    value: "5"
  },
]

现在,我想通过将 value 与相同的 name 组合成一个数组来将此数组缩减为单个对象。像这样 -

{
  abc: [1, 3, 4],
  xyz: [2, 5]
}

如何使用 JavaScript 中的 reduce 执行此操作?

我不确定这是否是正确的方法,但我已经尝试过类似的方法,但它没有给我想要的输出。

const data = arr.reduce((acc, item) => {
  return {
    ...acc,
    [item.name]: [item.value, acc[item.value]]
  };
});

const data=[
  {
name: "abc",
value: "1"
  },
  {
name: "xyz",
value: "2"
  },
  {
name: "abc",
value: "3"
  },
  {
name: "abc",
value: "4"
  },
  {
name: "xyz",
value: "5"
  },
];

const res=data.reduce((a,c)=>{
 (a[c.name]??=[]).push(c.value);
 return a;
},{});
console.log(res);

你的答案是正确的,但你需要检查 acc 是否已经有 item.name 的密钥:

const data = [{
    name: "abc",
    value: "1"
  },
  {
    name: "xyz",
    value: "2"
  },
  {
    name: "abc",
    value: "3"
  },
  {
    name: "abc",
    value: "4"
  },
  {
    name: "xyz",
    value: "5"
  },
]

const result = data.reduce((acc, { name, value }) => ({
  ...acc,
  [name] : [...(acc[name] || []), value]
}), {})

console.log(result)

请注意,您可以使用对象解构来简化累积代码。

const data = [{
    name: "abc",
    value: "1"
  },
  {
    name: "xyz",
    value: "2"
  },
  {
    name: "abc",
    value: "3"
  },
  {
    name: "abc",
    value: "4"
  },
  {
    name: "xyz",
    value: "5"
  },
];

let finalObject = {};

data.forEach((item) => {
   if (!finalObject.hasOwnProperty(item.name)) {
      finalObject[item.name] = [item.value];
   } else {
      finalObject[item.name].push(item.value);
   }
});
console.log(finalObject);

如果您需要将字符串转换为数字,只需解析值即可得到答案

{
  abc: [1, 3, 4],
  xyz: [2, 5]
}

您可以使用 Array.prototype.reduce 对数组进行分组。

const 
  data = [
    { name: "abc", value: "1" },
    { name: "xyz", value: "2" },
    { name: "abc", value: "3" },
    { name: "abc", value: "4" },
    { name: "xyz", value: "5" },
  ],
  result = data.reduce((r, o) => ((r[o.name] ??= []).push(o.value), r), {});

console.log(result);

reduce 需要一些时间来习惯,但是一旦点击就相当简单。您还可以使用简单的 for...of 循环对数组进行分组。

const data = [
  { name: "abc", value: "1" },
  { name: "xyz", value: "2" },
  { name: "abc", value: "3" },
  { name: "abc", value: "4" },
  { name: "xyz", value: "5" },
];

const result = {};
for (let d of data) {
  (result[d.name] ??= []).push(d.value);
}

console.log(result);

其他相关文件:

使用reduce():

const arr = [
  {
    name: "abc",
    value: "1"
  },
  {
    name: "xyz",
    value: "2"
  },
  {
    name: "abc",
    value: "3"
  },
  {
    name: "abc",
    value: "4"
  },
  {
    name: "xyz",
    value: "5"
  },
]

const data = arr.reduce((a,c) => ({...a, [c.name]: a[c.name] ? [...a[c.name], c.value] : [c.value]}),{})
console.log(data)