繁体   English   中英

如何将嵌套对象数组动态转换为单个数组

[英]How to convert nested object array to single array dynamically

// 我有这种多对象

_id: "5e5d00337c5e6a0444d00304"
    orderID: 10355
    orderDate: "2020-03-02"
    user:
       _id: "5e2e9699a648c53154f41025"
       name: "xyz1"
       email: "abcde@gmail.com"
       mNumber: 12336

// 我想把它放在一个数组中

orderID: 10354, 10355
orderDate:"2020-03-02","2020-03-02"
name: "xyz", "xyz1"
email: "abcd@gmail.com", "abcde@gmail.com"
mNumber: 1234536, 12336

我的主要目标是获取 Excel 表,在这些标题下,ID 名称电子邮件等我得到这些数据。 喜欢

orderID    orderDate    name   email           mNumber
10354      2020-03-02   xyz   abcd@gmail.com   1234536
10355      2020-03-02   xyz1   abcde@gmail.com   12336

这应该如何在 Angular 中完成?

如果我理解正确,你可以做这样的事情,

objs = [
  {
    _id: "5e5d00337c5e6a0444d00304",
    orderID: 10354,
    orderDate: "2020-03-02",
    user:
    {
      _id: "5e2e9699a648c53154f41025",
      name: "xyz",
      email: "abcd@gmail.com",
      mNumber: 1234536
    }
  },
  {
    _id: "5e5d00337c5e6a0444d00304",
    orderID: 10355,
    orderDate: "2020-03-02",
    user:
    {
      _id: "5e2e9699a648c53154f41025",
      name: "xyz1",
      email: "abcde@gmail.com",
      mNumber: 12336
    }
  }
];
const arr = [];
for (const o of objs) {
  arr.push([
    o.orderID,
    o.orderDate,
    o.user.name,
    o.user.email,
    o.user.mNumber
  ]);
}
console.log(arr);

这是输出,

[ [ 10354, '2020-03-02', 'xyz', 'abcd@gmail.com', 1234536 ],
  [ 10355, '2020-03-02', 'xyz1', 'abcde@gmail.com', 12336 ] ]

基本上它只是一个迭代。

我将添加另一个解决方案。 在这种情况下,您不想描述行中的所有值,而是想描述行中不需要的值。 在这种情况下,您可以使用递归函数来遍历对象。 fields是您描述的值的对象,而女巫则没有。 像这样的东西。

const fields = { _id: false, user: { _id: false} }
function toRowRec(obj, fields) {
  let row = [];
  const keys = Object.keys(obj);
  for (const k of keys) {
    if (!fields.hasOwnProperty(k)) {
      row.push(obj[k]);
    } else if (typeof obj[k] === 'object' && obj[k] !== null) {
      row = row.concat(toRowRec(obj[k], fields[k])); 
    }
  }
  return row;
}
let arr = []
for (const o of objs) {
  arr.push(toRowRec(o, fields));
}
console.log(arr);

我省略了输入objs (与之前相同),您将获得比以前更准确的输出。

你会看到我也省略了我想放在行中的键,为此我只是检查键是否在fields对象中。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM