如何解决如何将对象数组转换为嵌套对象?
你好,我试着得到这个输出
{
name: "Saviole",role: "ceo",children: [
{
name: "Mary",role: "supervisorA",children: [
{name: "Anna",role: "worker"}
]
},{
name: "Louis",role: "supervisorB"
}]
}
这些是我写的函数:
const users = [
{name: "Anna",role: "worker"},{ name: "Mary",role: "supervisorA" },{ name: "Louis",role: "supervisorB" },{ name: "Saviole",role: "ceo" }
];
const recursiveAddToTree = (parent,child,grandChildren,users)=>{
let tree = {};
users.forEach(( user)=>{
if(user.role===parent){
tree ={...user}
} else if(user.role===child){
tree = {...tree,chidren:[...[user]]}
} else {
users.forEach(userChild=>{
if(userChild.role===child){
tree = {...tree,children:[...[{...userChild,chidren: [...[user]]}]]}
}
})
}
})
return tree;
}
const createSchema = users =>{
return recursiveAddToTree("ceo","supervisorA","worker",users)
}
我该如何解决这个问题?我不明白为什么它不像想象的那样工作
解决方法
我在您的代码中看到了 2 个问题:
- foreach 会一个一个处理用户,最后一个处理:ceo。但是在您的代码中,如果处理的用户是 CEO,您的树对象将被用户替换,因此您之前的所有修改都将被删除(我认为这是最重要的问题)
- 主管的角色是“主管A”和“主管B”,但是您正在检查角色是否为“主管”,它永远不会匹配,您应该检查角色是否以“主管”开头
您可以采用一个排序数组,其中所有用户都按照上面直接角色下的角色进行排序,并采用一个对象来获取角色的级别。然后迭代并获取一个级别数组以跟踪最后一个用户并根据角色/级别插入用户。
这种方法保持给定的顺序。
const
users = [
{ name: "Saviole",role: "ceo" },{ name: "Mary",role: "supervisor" },{ name: "Anna",role: "worker" },{ name: "Louis",role: "supervisor" }
],roles = { ceo: 0,supervisor: 1,worker: 2 },tree = [],levels = [tree];
users.forEach(user => {
const level = roles[user.role];
if (!levels[level]) {
const
temp = levels[level - 1],last = temp[temp.length - 1];
levels[level] = [];
last.children = levels[level];
}
levels[level].push(user);
});
console.log(tree);
.as-console-wrapper { max-height: 100% !important; top: 0; }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。