用js动态实现树型结构菜单

昨天写一个界面的时候需要实现一个树型结构菜单,因为之前没写过,所以就将自己的过程记录下来了:

先写一个静态的dom结构

html代码如下:

<ul class="menu">
        <li>
            <a href="#">1</a>
            <ul class="menu1">
                <li><a href="#">1.1</a></li>
                <li><a href="#">1.2</a></li>
                <li>
                    <a href="#">1.3</a>
                    <ul class="menu2">
                        <li><a href="#">1.3.1.1</a></li>
                        <li><a href="#">1.3.1.2</a></li>
                    </ul>
                </li>
            </ul>
        </li>
    </ul>

那么我的实现效果如下:

设置点击事件

先将下拉的元素隐藏,然后当我点击的时候将它隐藏和显示切换,用jQuery几行代码就实现啦
js代码如下:

$(function () {
    $(".menu ul").css("display", "none");
    $(".menu a").on("click", function () {
        $(this).next().toggle();
    });
});

那么此时我的效果如下:


点击之后效果如下:


(忽略我懒得弄个动图上来,捂脸,捂脸,捂脸)

将自己的json数据放进去

此时你就可以将之前的html文件中的静态数据删除,然后我们在js文件中动态去生成,那么我的html文件就只剩一个div

<div id="div">
</div>

此时我的js文件的代码如下:

function renderMenu(menu, parent) {
    var el = $('<a href="#">' + menu.name + '</a>');
    parent.append(el);
    if (!menu.hasOwnProperty("contents")) { //判断是否是叶子节点,根据自己的数据去判断
        return parent;
    }

    var ul = $('<ul/>');
    for (var i = 0; i < menu.contents.length; ++i) {
        var li = $('<li/>');
        renderMenu(menu.contents[i], li);
        ul.append(li);
    }

    parent.append(ul);
    return parent;
}

function render(data) {
    var div = $('<div/>');
    return renderMenu(data, div);
}

$(function () {
    var data = {
        "type": "directory", "name": "haha", "contents": [
            {"type": "file", "name": "2848"},
            {
                "type": "directory", "name": "_2848.extracted", "contents": [
                {"type": "file", "name": "3A03FC.xz"}
            ]
            }]
    }; //你自己的json数据
    var menu = render(data);

    $("#div").append(menu);
    $("#div ul").css("display", "none");
    $("#div a").on("click", function () {
        $(this).next().toggle();
    });
});

那么此时你自己的数据就生成树型结构菜单啦:

样式丑了点,根据个人喜好去调样式哦

demo代码地址:https://github.com/yangzhanmei/treeStructure-demo

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

推荐阅读更多精彩内容