let list = [ { pid: 0, id: 1, value: '总公司' }, { pid: 3, id: 2, value: '人事部-1' }, { pid: 1, id: 3, value: '人事部' }, { pid: 1, id: 4, value: '采购部' }, { pid: 1, id: 5, value: '组织部' }, ]; function listToTree(list){ //遍历整个列表 return list.filter(cur=>{ // 获取当前节点的子节点 let children= list.filter(item=> item.pid== cur.id ); if(children.length>0){ cur.children=children; } //只返回顶级节点 return cur.pid==0; }); } console.log(listToTree(list));