list转成tree返回前端

参考网址人家是封装的反射,泛型

耻辱,现在不会用他们封装的方法

到处之前excel导入的数据,参照之前写的网址poi低版本导入excel表头

就贴一个control层

java 复制代码
  @GetMapping(value = "/all")
    @Log("查询excel测试导入表头不带分页")
    @ApiOperation("查询excel测试导入表头不带分页")
//    @PreAuthorize("@el.check('sysTest:list')")
    public ResponseEntity<PageResult<SysTest>> querySysTest(SysTestQueryCriteria criteria){
        List<SysTest> sysTests = sysTestService.queryAll(criteria);
//        将list处理成tree
        ArrayList<SysTest> roots = new ArrayList<>();
        for (SysTest tree:sysTests){
            String parentlevel = tree.getParentlevel();
            if(StrUtil.isBlank(parentlevel)){
                roots.add(tree);
            }
        }
        sysTests.removeAll(roots);
        // 为根节点添加孩子节点
        for (SysTest tree:roots){
            addChild(tree,sysTests);
        }
//        System.out.println(roots);
        return new ResponseEntity<>(PageUtil.toPage(roots),HttpStatus.OK);
    }

    public void addChild(SysTest tree,List<SysTest> sysTests){
        String headid = tree.getHeadid();
        List<SysTest> children = tree.getChildren();
        for(SysTest cc : sysTests){
            if(headid.equals(cc.getParentlevel())){
                if(children == null){
                    children = new ArrayList<>();
                }
                children.add(cc);
//                写死的时候才知道人家封装说的(我debug发现自己是null,没有初始化)
// 重设目标节点的孩子节点集合,这里必须重设,因为如果目标节点的孩子节点是null的话,这样是没有地址的,就会造成数据丢失,所以必须重设,如果目标节点所在类的孩子节点初始化为一个空集合,而不是null,则可以不需要这一步,因为java一切皆指针
                tree.setChildren(children);
                addChild(cc,sysTests);
            }
        }
    }
相关推荐
Wyc724094 分钟前
Maven
java·数据库·maven
程序猿小D7 分钟前
[附源码+数据库+毕业论文]基于Spring+MyBatis+MySQL+Maven+jsp实现的电影小说网站管理系统,推荐!
java·数据库·mysql·spring·毕业设计·ssm框架·电影小说网站
爱分享的程序员10 分钟前
前端面试专栏-算法篇:18. 查找算法(二分查找、哈希查找)
前端·javascript·node.js
翻滚吧键盘16 分钟前
vue 条件渲染(v-if v-else-if v-else v-show)
前端·javascript·vue.js
vim怎么退出17 分钟前
万字长文带你了解微前端架构
前端·微服务·前端框架
你这个年龄怎么睡得着的17 分钟前
为什么 JavaScript 中 'str' 不是对象,却能调用方法?
前端·javascript·面试
Java水解20 分钟前
前端常用单位em/px/rem/vh/vm到底有什么区别?
前端
CAD老兵23 分钟前
Vite 如何借助 esbuild 实现极速 Dev Server 体验,并支持无 source map 的源码调试
前端
南屿im24 分钟前
JavaScript 手写实现防抖与节流:优化高频事件处理的利器
前端·javascript
Spider_Man24 分钟前
从零开始构建React天气应用:API集成与UI设计全指南 🌤️
前端·react.js