码迷,mamicode.com
首页 > 其他好文 > 详细

线性结构转树形结构(生成无限层级菜单)

时间:2019-12-24 13:24:13      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:color   code   cti   无限   ret   listt   return   fun   结构   

let list = [ 
    { parentId: 0, id: 1, value: ‘1‘ },
    { parentId: 3, id: 2, value: ‘2‘ }, 
    { parentId: 0, id: 3, value: ‘3‘ },
    { parentId: 1, id: 4, value: ‘4‘ }, 
    { parentId: 1, id: 5, value: ‘5‘ }, 
]; 

function listToTree(list){
    //遍历整个列表
    return list.filter(cur=>{ 
        // 获取当前节点的子节点
        let children= list.filter(item=> item.parentId == cur.id ); 
        if(children.length>0){
             cur.children=children;
        }
        //只返回顶级节点
        return cur.parentId==0; 
    });
}

console.log(listToTree(list));

线性结构转树形结构(生成无限层级菜单)

标签:color   code   cti   无限   ret   listt   return   fun   结构   

原文地址:https://www.cnblogs.com/flamestudio/p/12090848.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!