首页 > 其他 > 详细

将查出来的数据拼树状结构

时间:2021-03-02 22:25:03      阅读:28      评论:0      收藏:0      [点我收藏+]
    public List<SysMenu> getSysMenuByRoleId(Integer roleId) throws Exception {
        try {
            ArrayList<SysMenu> tempList = new ArrayList<>();
            List<SysMenu> smList = sysMenuMapper.getSysMenuByRoleId(roleId);
            for (SysMenu sysMenu : smList) {
                //判断找出父节点
                if (sysMenu.getParentId() == null) {
                    //把所有父节点保存到一起
                    tempList.add(sysMenu);
                } else {
                    //遍历所有的父节点
                    for (SysMenu menu : tempList) {
                        if (menu.getId().equals(sysMenu.getParentId())) {
                            //找出子节点对应的父节点,然后填充
                            List<SysMenu> children = menu.getChildren();
                            if (children == null)
                                children = new ArrayList<>();
                            children.add(sysMenu);
                            menu.setChildren(children);
                        }
                    }
                }
            }
            smList.sort(Comparator.comparing(SysMenu::getId));
            return smList;
        } catch (Exception e) {
            log.error("【根据RoleId获取SysMenu数据异常】异常信息为:" + e.getMessage());
            throw new Exception(e.getMessage());
        }
    }

 

showtooltip

将查出来的数据拼树状结构

原文:https://www.cnblogs.com/coding8832/p/14470852.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!