原生js动态生成树形菜单

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>原生js动态生成树形菜单 </title>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/1.8.3/jquery.min.js"></script>
</head>
<body>
    <div id="menuTree" class="menuTree"></div>
</body>
<style>
    .menuTree div {
        padding-left: 20px;
    }

    .menuTree div ul {
        overflow: hidden;
        display: none;
        height: auto;
    }

    .menuTree span {
        display: block;
        height: 25px;
        line-height: 25px;
        padding-left: 5px;
        margin: 1px 0;
        cursor: pointer;
        border-bottom: 1px solid #CCC;
    }

    .menuTree span:hover {
        background-color: #e6e6e6;
        color: #cf0404;
    }

    .menuTree a {
        color: #333;
        text-decoration: none;
    }

    .menuTree a:hover {
        color: #06F;
    }

    .btn {
        height: 30px;
        margin-top: 10px;
        border-bottom: 1px solid #CCC;
    }
</style>
<script type="text/javascript">
    var json = [{
            "name": "1级菜单",
            "list": [{
                    "name": "2级菜单",
                    "url": "/url1"
                },
                {
                    "name": "2级菜单",
                    "list": [{
                            "name": "3级菜单",
                            "list": [{
                                "name": "4级菜单",
                                "url": "/url111"
                            }, {
                                "name": "4级菜单",
                                "list": [{
                                    "name": "5级菜单",
                                    "url": "/url1111"
                                }, {
                                    "name": "5级菜单",
                                    "url": "/url1112"
                                }]
                            }]
                        },
                        {
                            "name": "3级菜单",
                            "url": "/url13"
                        },
                        {
                            "name": "3级菜单",
                            "url": "/url14"
                        }
                    ]
                },
                {
                    "name": "2级菜单",
                    "url": "/url3"
                }
            ]
        },
        {
            "name": "1级菜单",
            "list": [{
                    "name": "2级菜单",
                    "url": "/url1"
                },
                {
                    "name": "2级菜单",
                    "list": [{
                            "name": "3级菜单",
                            "url": "/url111"
                        },
                        {
                            "name": "3级菜单",
                            "url": "/url112"
                        }
                    ]
                },
            ]
        },
        {
            "name": "1级菜单",
            "list": [{
                    "name": "2级菜单",
                    "url": "/url1"
                },
                {
                    "name": "2级菜单",
                    "url": "/url2"
                }
            ]
        },
        {
            "name": "1级菜单"
        }
    ]
    /*递归实现获取多级树数据并生成DOM结构*/
    var str = "";
    var forTree = function (o) {
        for (var i = 0; i < o.length; i++) {
            var urlstr = "";
            try {
                if (typeof o[i]["url"] == "undefined") {
                    urlstr = "<div><span>" + o[i]["name"] + "</span><ul>";
                } else {
                    urlstr = "<div><span><a href=" + o[i]["url"] + ">" + o[i]["name"] + "</a></span><ul>";
                }
                str += urlstr;
                if (o[i]["list"] != null) {
                    forTree(o[i]["list"]);
                }
                str += "</ul></div>";
            } catch (e) {}
        }
        return str;
    }
    /*添加多级树*/
    document.getElementById("menuTree").innerHTML = forTree(json);
    /*树形菜单*/
    var menuTree = function () {
        //所有父元素加[+-]
        $("#menuTree ul").each(function (index, element) {
            var ulContent = $(element).html();
            var spanContent = $(element).siblings("span").html();
            if (ulContent) {
                $(element).siblings("span").html("[+] " + spanContent)
            }
        });

        $("#menuTree").find("div span").click(function () {
            var ul = $(this).siblings("ul");
            var spanStr = $(this).html();
            var spanContent = spanStr.substr(3, spanStr.length);
            if (ul.find("div").html() != null) {
                if (ul.css("display") == "none") {
                    ul.show(300);
                    $(this).html("[-] " + spanContent);
                } else {
                    ul.hide(300);
                    $(this).html("[+] " + spanContent);
                }
            }
        })
    }()

    /*展开*/
    $("#btn_open").click(function () {
        $("#menuTree ul").show(300);
        curzt("-");
    })
    /*收缩*/
    $("#btn_close").click(function () {
        $("#menuTree ul").hide(300);
        curzt("+");
    })

    function curzt(v) {
        $("#menuTree span").each(function (index, element) {
            var ul = $(this).siblings("ul");
            var spanStr = $(this).html();
            var spanContent = spanStr.substr(3, spanStr.length);
            if (ul.find("div").html() != null) {
                $(this).html("[" + v + "] " + spanContent);
            }
        });
    }
</script>
</html>

效果图
在这里插入图片描述

  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Spring JPA中生成树菜单可以通过以下步骤进行实现: 1. 首先,需要在数据库中创建一个用于存储菜单信息的表,表结构至少需要包含id、菜单名、父菜单id等字段。可以使用`@Entity`注解来定义这个菜单实体类,并使用`@Table`注解来指定对应的数据库表。 2. 在实体类中,可以使用`@ManyToOne`注解定义菜单与父菜单的关联关系,表示该菜单对应的父菜单。这样就能够通过父菜单id查询到对应的父菜单信息。 3. 在菜单实体类中,可以添加一个名为`children`的字段,该字段用来存储该菜单的子菜单信息。使用`@OneToMany`注解定义菜单与子菜单的关联关系,并通过`mappedBy`属性指定关联关系的字段。 4. 创建一个自定义的Repository接口,继承`JpaRepository`接口,并自定义一个查询方法,用于根据父菜单id查询子菜单列表。在自定义方法上使用`@Query`注解,并编写JPQL查询语句,通过`@Query`注解中的`nativeQuery`属性指定是否使用原生的SQL查询。 5. 在Controller中,注入自定义的Repository接口,并通过调用自定义方法查询到根节点的菜单列表。 6. 通过递归的方式将查询到的根节点菜单信息组装成树结构,可以使用一个递归方法来实现这个过程。该方法接收一个菜单列表作为参数,先遍历菜单列表,找到根节点菜单,然后递归调用该方法,将该根节点菜单的子菜单列表作为参数传入。 7. 在前端展示时,可以通过遍历树结构,依次展示菜单的层级关系和子菜单。 通过以上步骤,就可以在Spring JPA中生成树菜单了。注意,树结构的生成主要是通过数据库的表结构和实体类的关联关系来实现的,而查询和组装树结构的逻辑需要在后端进行处理,然后将生成的树菜单传给前端进行展示。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值