Java返回树形结构的数据 (children方式)

以children这种方式的实体类来遍历子父级的树形结构。

//问题分类下拉表
@Override
public List<DA> selectDA(Long deptId,Long userId) {

        //根据deptId获取当前parentId  --- 第一步就是:获取根节点。
        DA current = sysDropDownListMapper.selectDA(deptId);
        //以下是可以拿到子部门内容
        DA root;
        //如果parentId为0,说明是根目录了。不是0就查找它的上级作为目录。
        if (current.getParentId()!=0){
            root = sysDropDownListMapper.selectDA(current.getParentId());
        }else {
            root = current;
        }

        //因为不需要返回parentId,所以返回同级就可以了。
        DA item = getItem(root);
        List<DA> list = item.getChildren();
        return list;
}

/**
 *  采用递归方式来获取树
 */
private DA getItem(DA parentItem){
    //查询所有parentId为该数据的data --- 第二步:就是循环遍历parentId为该数据的 data。
    List<DA> items = sysDropDownListMapper.selectDAByParentId(parentItem.getDeptId());
    if (items!=null){
        parentItem.setChildren(items);
        for (DA item : items) {
            getItem(item);
        }
    }
    return parentItem;
}

对应实体类:

  • 通过children这种方式来给前端显示子父级关系。
package com.ruoyi.system.domain;

import java.util.List;

public class DA {
    Long deptId;
    String deptName;
    Long parentId;
    List<DA> children;

    public Long getParentId() {
        return parentId;
    }

    public void setParentId(Long parentId) {
        this.parentId = parentId;
    }

    public Long getDeptId() {
        return deptId;
    }

    public void setDeptId(Long deptId) {
        this.deptId = deptId;
    }

    public String getDeptName() {
        return deptName;
    }

    public void setDeptName(String deptName) {
        this.deptName = deptName;
    }

    public List<DA> getChildren() {
        return children;
    }

    public void setChildren(List<DA> children) {
        this.children = children;
    }
}
  • 0
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是一个例子,展示如何返回一个树形菜单结构的数据: 1. 先定义一个树节点的类: ```java public class TreeNode { private String id; private String name; private List<TreeNode> children; // 构造方法和getter/setter } ``` 2. 然后编写一个方法递归遍历树形结构,并返回根节点: ```java public TreeNode buildTree(List<MenuItem> menuItems) { // 先构建一个空的根节点 TreeNode root = new TreeNode(); root.setId("0"); root.setName("根节点"); root.setChildren(new ArrayList<TreeNode>()); // 把所有一级菜单节点找出来,加入到根节点下面 for (MenuItem menuItem : menuItems) { if (menuItem.getParentId().equals("0")) { TreeNode child = new TreeNode(); child.setId(menuItem.getId()); child.setName(menuItem.getName()); child.setChildren(new ArrayList<TreeNode>()); root.getChildren().add(child); } } // 遍历每个子节点,递归构建树 for (TreeNode child : root.getChildren()) { buildSubtree(child, menuItems); } return root; } private void buildSubtree(TreeNode parent, List<MenuItem> menuItems) { for (MenuItem menuItem : menuItems) { if (menuItem.getParentId().equals(parent.getId())) { TreeNode child = new TreeNode(); child.setId(menuItem.getId()); child.setName(menuItem.getName()); child.setChildren(new ArrayList<TreeNode>()); parent.getChildren().add(child); buildSubtree(child, menuItems); } } } ``` 3. 最后,需要一个表示菜单项的类: ```java public class MenuItem { private String id; private String name; private String parentId; // 构造方法和getter/setter } ``` 使用示例: ```java List<MenuItem> menuItems = new ArrayList<>(); menuItems.add(new MenuItem("1", "菜单1", "0")); menuItems.add(new MenuItem("2", "菜单2", "0")); menuItems.add(new MenuItem("3", "菜单3", "1")); menuItems.add(new MenuItem("4", "菜单4", "1")); menuItems.add(new MenuItem("5", "菜单5", "2")); menuItems.add(new MenuItem("6", "菜单6", "3")); menuItems.add(new MenuItem("7", "菜单7", "3")); TreeNode root = buildTree(menuItems); ``` 最终得到的树形结构: ``` 根节点 ├── 菜单1 │ ├── 菜单3 │ │ └── 菜单6 │ └── 菜单4 └── 菜单2 └── 菜单5 └── 菜单7 ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

xupengboo

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

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

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

打赏作者

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

抵扣说明:

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

余额充值