数组转换树形结构

菜单数据

var menus = [
    { id: '1', pid: '0', title: '用户管理' },
    { id: '2', pid: '0', title: '角色管理' },
    { id: '3', pid: '0', title: '设备管理' },
    { id: '4', pid: '1', title: '用户列表' },
    { id: '5', pid: '1', title: '编辑用户' },
    { id: '6', pid: '2', title: '角色列表' },
    { id: '7', pid: '2', title: '编辑角色' },
    { id: '8', pid: '3', title: '设备列表' },
];

转换结构 

// 递归组成树结构
function arr2Tree(arr, id = '0') {
    var results = [];
    arr.forEach(item => {
        if(item.pid === id) {
            var d = {...item};
            var children = arr2Tree(arr, d.id);
            if(children?.length) d.children = children;
            results.push(d);
        }
    });
    return results;
}

arr2Tree(menus); // 返回树结构

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值