平行数据转换树形数据

let arr = [ { id: 3, name: "部门3", pid: 1 }, { id: 1, name: "部门1", pid: 0 }, { id: 5, name: "部门5", pid: 4 }, { id: 2, name: "部门2", pid: 1 }, { id: 4, name: "部门4", pid: "fff" } ]; function listToTree(arr) { const result = []; const map = new Map(); arr.forEach((item) => { map.set(item.id, item); }); for (let item of arr) { if (map.has(item.pid)) { map.get(item.pid).children ??= []; map.get(item.pid).children.push(item); } else { result.push(item); } } return result; }

posted @   红尘卟卟  阅读(27)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】
点击右上角即可分享
微信分享提示