//我有这种多对象
_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名称为email,以此类推。 像
orderID orderDate name email mNumber
10354 2020-03-02 xyz abcd@gmail.com 1234536
10355 2020-03-02 xyz1 abcde@gmail.com 12336
这应该在Angular中完成吗?
答案 0 :(得分:1)
如果我对您的理解正确,则可以执行以下操作
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
对象中。