使用Hutool工具的TreeUtil快速的生成树

使用Hutool工具的TreeUtils快速的生成树

1 依赖包

<dependency>
     <groupId>cn.hutool</groupId>
     <artifactId>hutool-all</artifactId>
     <version>5.8.11</version>
</dependency>

2 案列

假设我们有一个层级的表 parentid就是他的上一级
在这里插入图片描述

2.1 代码

    public List<Tree<Integer>> getAll() {
        List<Dept> deptList = deptMapper.selectAll();
        TreeNodeConfig treeNodeConfig = new TreeNodeConfig();
        treeNodeConfig.setIdKey("id");
        treeNodeConfig.setParentIdKey("parentId");
        // 设置层级  也就是有几级子目录这种关系
        treeNodeConfig.setDeep(3);
        List<Tree<Integer>> build = TreeUtil.build(deptList, 0, treeNodeConfig, (treeNode, tree) -> {
            tree.setId(treeNode.getId()); //id
            tree.setParentId(treeNode.getParentId()); //父id
            //TODO 返回的时候字段
            tree.putExtra("id",treeNode.getId());
            tree.putExtra("parentId",treeNode.getParentId());
            tree.putExtra("name",treeNode.getName());
        });
            return build;
    }
}

解释:

首先就是获取全部的数据
TreeNodeConfig 进行一些配置
然后就是转换器 putExtra

TreeNodeConfig默认的配置是:

    private String idKey = "id"; 主键id
    private String parentIdKey = "parentId"; 父id
    private String weightKey = "weight"; 根据权重进行排序
    private String nameKey = "name"; 
    private String childrenKey = "children";

2.2 结果

在这里插入图片描述

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

长安有故里y

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值