树形结构写法(子父级)(菜单 按钮)

该博客主要介绍了如何使用Java将数据库中的菜单数据转换为树形结构。通过定义POJO类`UmsMenu`和`UmsMenuNode`,实现了数据的层级关系。在`treeList`方法中,利用流操作筛选出根节点,并递归地构建子节点,最终形成树形结构的菜单列表。这个过程涉及到对象的复制、过滤和映射等操作。
摘要由CSDN通过智能技术生成

数据库中的格式

 

pojo类

public class UmsMenu implements Serializable {
    @ApiModelProperty(value = "唯一标识")
    private Long id;

    @ApiModelProperty(value = "父级ID")
    private Long parentId;

    @ApiModelProperty(value = "创建时间")
    private Date createdate;

    @ApiModelProperty(value = "菜单名称")
    private String title;

    @ApiModelProperty(value = "菜单级数")
    private Integer level;

    @ApiModelProperty(value = "菜单排序")
    private Integer sort;

    @ApiModelProperty(value = "前端名称")
    private String name;

    @ApiModelProperty(value = "前端图标")
    private String icon;

    @ApiModelProperty(value = "是否隐藏")
    private Integer hidden;

    @ApiModelProperty(value = "备用字段1")
    private String fbk1;

    @ApiModelProperty(value = "备用字段3")
    private String fbk2;

    @ApiModelProperty(value = "备用字段3")
    private String fbk3;

返回的vo树形结构类

public class UmsMenuNode extends UmsMenu {
    @ApiModelProperty(value = "子级菜单")
    private List<UmsMenuNode> children;
}

代码实现

@Override
public List<UmsMenuNode> treeList() {
//得到数据库中所有的数据
    UmsMenuExample example = new UmsMenuExample();
    List<UmsMenu> menuList = menuMapper.selectByExample(example);
//得到子父关系的list的
    List<UmsMenuNode> result = menuList.stream()
            .filter(menu -> menu.getParentId().equals(0L))
            .map(menu -> covertMenuNode(menu, menuList)).collect(Collectors.toList());
    return result;
}
/**
 * 将UmsMenu转化为UmsMenuNode并设置children属性
 */
private UmsMenuNode covertMenuNode(UmsMenu menu, List<UmsMenu> menuList) {
    UmsMenuNode node = new UmsMenuNode();
    BeanUtils.copyProperties(menu, node);
    List<UmsMenuNode> children = menuList.stream()
            .filter(subMenu -> subMenu.getParentId().equals(menu.getId()))
            .map(subMenu -> covertMenuNode(subMenu, menuList)).collect(Collectors.toList());
    node.setChildren(children);
    return node;
}

得到的结果

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值