基于JAVA实现的N层菜单(树形结构)

适用于多层菜单的设计

 /**
     * @Description 生成树形结构nodeTree; List tagList原始无序数据链表
     * @auther: wz
     * @date: 2019/1/18 15:09
     */
    private List<TagBinaryTree> createNodeTree(List tagList) {
        long beginTime = System.currentTimeMillis();
        logger.info("节点树构型开始---时间:" + beginTime);
        Iterator<Tag> iterable = tagList.iterator();
        List<TagBinaryTree> finalList = new ArrayList();
        List<TagBinaryTree> remainList = new ArrayList<>();//没找到父节点的节点集合
        while (iterable.hasNext()) {
            Tag tag1 = iterable.next();
            TagBinaryTree binaryTree = new TagBinaryTree(tag1, new ArrayList<TagBinaryTree>());
            if (tag1.getParentId() == 0) {//找出一级标签
                finalList.add(binaryTree);
                iterable.remove();//从集合中移除一级标签
            } else {
                boolean findResult = findNode(finalList, binaryTree);
                if (!findResult)
                    remainList.add(binaryTree);
            }
        }
        //处理剩余没找到父节点的节点 1.不会存在一级标签 2.不确定顺序
        //1.遍历剩余集合 自己匹配
        Iterator<TagBinaryTree> remainIterator = remainList.iterator();
        while (remainIterator.hasNext()) {
            TagBinaryTree remainNode = remainIterator.next();
            logger.info("");
            //自己匹配
            boolean Result = findNode(remainList, remainNode);
            if (Result) remainIterator.remove();
        }

        //2.匹配最终树
        Iterator<TagBinaryTree> remainIterator2 = remainList.iterator();
        while (remainIterator2.hasNext()) {
            TagBinaryTree remainNode = remainIterator2.next();
            boolean findResult = findNode(finalList, remainNode);
            if (findResult) remainIterator2.remove();
        }
        //处理之后还有剩余 余下节点将作为一级节点
        if (remainList.size() > 0) {
            logger.info("处理剩余节点后还有剩余,将节点添加到一级节点集合中");
            for (TagBinaryTree tagBinaryTree : remainList)
                finalList.add(tagBinaryTree);
        }
        long endTime = System.currentTimeMillis();
        logger.info("节点树构型结束---时间:" + endTime);
        logger.info("耗时:" + (endTime - beginTime));
        return finalList;
    }

    /**
     * @Description 遍历树 找到位置 递归
     * srcTreeList 树结构  目标节点 targetBinaryTree
     * @auther: wz
     * @date: 2019/1/18 12:35
     */
    private boolean findNode(List<TagBinaryTree> srcTreeList, TagBinaryTree targetBinaryTree) {
        Iterator iterator = srcTreeList.iterator();
        while (iterator.hasNext()) {
            TagBinaryTree node = (TagBinaryTree) iterator.next();
            Tag srcTag = node.getTag();
            Tag tarTag = targetBinaryTree.getTag();
            if (srcTag.getId().equals(tarTag.getParentId())) {//找到父节点 添加到父节点下
                List<TagBinaryTree> srcChildrenList = node.getChildrenList();
                srcChildrenList.add(targetBinaryTree);
                return true;
            } else {//查找该节点下的子节点
                boolean findChildrenNodeResult = findNode(node.getChildrenList(), targetBinaryTree);
                if (findChildrenNodeResult) return true;
            }
        }
        return false;
    }

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容

  • 下午出门,真热。扫了辆助力车(附近一辆单车都没有,有的话谁爱花这两块钱,去的地方不远,路又好找。)到了小伙...
    讷言讷语阅读 328评论 0 1
  • 我决定罗列一下"我家橱柜"的物件儿清单: 第一层:4只盘子+1只酒壶+1只绿篮子(内盛豆腐)+3本书+1个书立(当...
    小女巫惠惠阅读 521评论 0 1
  • 小时候 爸爸妈妈常说 大队会计肚子里有墨水 能说会道 能写会算 赶巧 老师教我们学习毛笔字 我首先饱蘸一笔吸允 虽...
    月夜情诗阅读 1,264评论 26 19
  • 这个二月,坎坎坷坷,磕磕绊绊。 可能会成为记忆中最深刻的禁闭月。 新冠肺炎的肆意蔓延,如今已经让世卫组织将其危险程...
    小皮酱Sia阅读 111评论 0 1