Java生成Tree数据格式工具


现在系统有很多模块需要tree格式的json,应次需求搞一个通用的工具,该暂时只适合有父子关系的对象。

一、定义ITree接口

public interface ITree<T> {

    /**
     * 获取id
     *
     * @return
     */
    Integer getId();

    /**
     * 获取父id
     *
     * @return
     */
    Integer getParentId();

    /**
     * 获取孩子
     *
     * @return
     */
    List<T> getChildren();

    /**
     * 设置孩子
     *
     * @param children
     */
    void setChildren(List<T> children);
}

二、继承ITree接口并实现方法

@Data
public class MenusVo implements ITree<MenusVo> {
    /**
     * 菜单名
     */
    private Integer id;

    /**
     * 菜单名
     */
    private String authName;

    /**
     * 访问路径
     */
    private String path;

    /**
     * 父菜单id
     */
    private Integer parentId;

    /**
     * 子菜单
     */
    private List<MenusVo> children;
}

三、工具类编写

public class ConvertUtil {

    private ConvertUtil() {
    }

	/**
     * 集合转二叉树
     *
     * @param resource  来源集合
     * @param predicate 根节点标识判断
     * @return
     */
    public static <T extends ITree> List<T> convertTree(List<T> resource, Predicate<? super T> predicate) {
        List<T> result = resource.stream().filter(predicate).collect(Collectors.toList());
        // 移出父级元素
        resource.removeIf(result::contains);
        ConvertUtil.setChilder(result, resource);
        return result;
    }

    /**
     * 设置孩子
     *
     * @param parentList 根节点集合
     * @param elements 来源集合
     * @param <T>
     */
    private static <T extends ITree> void setChilder(List<T> parentList, List<T> elements) {
        if (CollUtil.isEmpty(elements)) {
            return;
        }
        // 遍历父级
        parentList.forEach(parent -> {
            List<T> childer = elements.stream().filter(element -> parent.getId().equals(element.getParentId())).collect(Collectors.toList());
            parent.setChildren(childer);
            elements.removeIf(childer::contains);
            setChilder(childer, elements);
        });
    }
}

四、工具类调用

public ResponseEntity tree() {
	List<MenusVo> menusList = ConvertUtil.convertList(menusService.list(null), MenusVo.class);
    List<MenusVo> result = ConvertUtil.convertTree(menusList, menusVo -> 0 == menusVo.getParentId());
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值