亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jquery 無限級下拉菜單的簡單實現代碼

2019-11-20 21:03:58
字體:
來源:轉載
供稿:網友
本例子使用json數據,拼接ul和li來實現的
效果圖:




1.準備json數據:
復制代碼 代碼如下:

var menuData = [
            {id:0,pid:-1,name:"訂購產品",url:"",children:[
                {id:1,pid:0,name:"電腦配件",url:"http://www.49028c.com",children:[
                    {id:20,pid:1,name:"cpu",url:"http://www.49028c.com",children:[
                        {id:30,pid:20,name:"Intel",url:"http://www.49028c.com",children:[
                            {id:3000,pid:30,name:"Intel 01",url:""},
                            {id:3001,pid:30,name:"Intel 02",url:""},
                            {id:3002,pid:30,name:"Intel 03",url:""},
                            {id:3003,pid:30,name:"Intel 04",url:""},
                            {id:3004,pid:30,name:"Intel 05",url:""},
                            {id:3005,pid:30,name:"Intel 06",url:""},
                            {id:3006,pid:30,name:"Intel 07",url:""},
                            {id:3007,pid:30,name:"Intel 08",url:""},
                            {id:3008,pid:30,name:"Intel 09",url:""}
                        ]},
                        {id:31,pid:20,name:"AMD",url:"http://www.49028c.com",children:[
                            {id:3100,pid:31,name:"AMD 01",url:""},
                            {id:3101,pid:31,name:"AMD 02",url:""},
                            {id:3102,pid:31,name:"AMD 03",url:""},
                            {id:3103,pid:31,name:"AMD 04",url:""},
                            {id:3104,pid:31,name:"AMD 05",url:""},
                            {id:3105,pid:31,name:"AMD 06",url:""},
                            {id:3106,pid:31,name:"AMD 07",url:""},
                            {id:3107,pid:31,name:"AMD 08",url:""},
                            {id:3108,pid:31,name:"AMD 09",url:""}
                        ]}
                    ]},
                    {id:21,pid:1,name:"內存",url:"http://www.49028c.com"},
                    {id:22,pid:1,name:"硬盤",url:"http://www.49028c.com"},
                    {id:23,pid:1,name:"主板",url:"http://www.49028c.com"},
                    {id:24,pid:1,name:"顯卡",url:"http://www.49028c.com"},
                    {id:25,pid:1,name:"顯示器",url:"http://www.49028c.com"},
                    {id:26,pid:1,name:"主機箱",url:"http://www.49028c.com"},
                    {id:27,pid:1,name:"主機箱電源",url:"http://www.49028c.com"},
                    {id:28,pid:1,name:"鍵鼠(有線)",url:"http://www.49028c.com"},
                    {id:29,pid:1,name:"鍵鼠(無線)",url:"http://www.49028c.com"}
                ],url:"http://www.49028c.com"},
                {id:101,pid:0,name:"監控器材",children:[
                    {id:102,pid:101,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:103,pid:101,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:104,pid:101,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:112,pid:101,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:113,pid:101,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:114,pid:101,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:115,pid:101,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:116,pid:101,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:117,pid:101,name:"攝像頭",url:"http://www.49028c.com"}
                ],url:"http://www.49028c.com"},
                {id:201,pid:0,name:"數碼產品",children:[
                    {id:202,pid:201,name:"攝像頭",url:"http://www.49028c.com"}
                ],url:"http://www.49028c.com"},
                {id:301,pid:0,name:"網絡產品",children:[
                    {id:302,pid:301,name:"攝像頭",url:"http://www.49028c.com"}
                ],url:"http://www.49028c.com"},
                {id:401,pid:0,name:"打印耗材",children:[
                    {id:402,pid:401,name:"打印機",url:"http://www.49028c.com"},
                    {id:403,pid:401,name:"油墨",url:"http://www.49028c.com"},
                    {id:404,pid:401,name:"紙張",url:"http://www.49028c.com"},
                    {id:405,pid:401,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:406,pid:401,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:407,pid:401,name:"攝像頭",url:"http://www.49028c.com"},
                    {id:408,pid:401,name:"攝像頭",url:"http://www.49028c.com"}
                ],url:"http://www.49028c.com"}
            ]},
            {id:1000,pid:-1,name:"我的訂單",url:"",children:[
                {id:1001,pid:1000,name:"已過期訂單",url:""},
                {id:1001,pid:1000,name:"已付款訂單",url:""}
            ]},
            {id:2000,pid:-1,name:"公司信息",url:"",children:[
                {id:2001,pid:2000,name:"最新新聞",url:""},
                {id:2002,pid:2000,name:"公司地址",url:""}
            ]}
        ];

2.html代碼:
復制代碼 代碼如下:

<div id="menu"><ul id="baseMenu"></ul></div>

3.解析json數據(plugin-menu.js文件):剛學會寫jquery插件,寫的還比較亂,湊合著看吧
復制代碼 代碼如下:

(function($){
    $.fn.extend({
        menu:function(options){
            var defaults = {
                data:[],
                ulId:"baseMenu"
            };
            var options = $.extend(defaults, options);
            // 開始拼接ul,li
            $.each(options.data,function(i,v){
                var li = $("<li id='"+options.data[i].id+"' name='"+options.data[i].pid+"'></li>");
                var _a = $("<a>"+options.data[i].name+"</a>");
                _a.attr("href",options.data[i].url)
                    .appendTo(li);

                _each(options.data[i],li);
                li.appendTo($("#"+options.ulId));
            });
            // 給li添加事件
            $(this).find("li").hover(function(){
                var id = $(this).attr("id");
                $(this).find("ul[name='"+id+"']").show();
            },function(){
                var id = $(this).attr("id");
                $(this).find("ul[name='"+id+"']").hide();
            });
        }
    });
})(jQuery);

因為支持無限級,所以肯定會用到遞歸方法:
復制代碼 代碼如下:

function _each(data,li){
    if(data==undefined||data.children==undefined){
        return false;
    }
    var ul = $("<ul name='"+data.id+"' style='display:none;'></ul>");

    $.each(data.children,function(i,v){
        var _li = $("<li id='"+data.children[i].id+"' name='"+data.children[i].pid+"'></li>");
        var _a = $("<a>"+data.children[i].name+"</a>");
        _a.attr("href",data.children[i].url)
            .attr("target","_blank")
            .appendTo(_li);

        if(data.children[i].children!=undefined){
            _each(data.children[i],_li);
        }
        _li.appendTo(ul);
    });
    ul.appendTo(li);
}

4.調用插件:
復制代碼 代碼如下:

$(function() {
    $("#menu").menu({data:menuData,ulId:"baseMenu"});
});

最后,css樣式:
復制代碼 代碼如下:

ul,li{list-style:none;padding:0px;margin:0px;}
#menu *{line-height:30px;}
#menu a{text-decoration:none;}
#menu ul{text-align:left;}
#menu>ul>li{text-align:center;width:80px;float:left;}
#menu>ul>li>a{color:#000;}
#menu>ul>li:hover{background:#F0F0F0;}
#menu>ul>li ul{display:none;width:150px;position:absolute;background:#c1cd94;box-shadow:2px 2px 2px #000;-webkit-box-shadow:2px 2px 2px #000;
  -moz-box-shadow:2px 2px 2px #123;}
#menu>ul>li>ul li{padding-left:5px; position:relative;}
#menu>ul>li>ul li>a{color:#000;}
#menu>ul>li>ul li:hover{background:#d3dbb3;}
#menu>ul>li>ul>li ul{left:150px; top:0px;}
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
日韩欧美成人网| 亚洲视频一区二区三区| 一区二区中文字幕| 日韩在线高清视频| 日韩精品中文字幕在线播放| 亚洲欧洲在线播放| 九九视频这里只有精品| 91在线视频免费| 久久国产一区二区三区| 久久久久久中文| 97超级碰在线看视频免费在线看| 亚洲精品在线看| 精品国产一区二区三区在线观看| 91在线高清免费观看| 国产在线视频欧美| 欧美午夜片欧美片在线观看| 亚洲va国产va天堂va久久| 亚洲欧美国产视频| 日韩亚洲综合在线| 日韩成人在线视频| 亚洲精品久久久久久久久| 日韩av电影在线播放| 国产一区二区三区精品久久久| 国内外成人免费激情在线视频网站| 久久久久久久久久久91| 色婷婷av一区二区三区在线观看| 日韩hd视频在线观看| 精品久久久国产精品999| 国产精品一区二区三区久久久| 欧美激情一区二区三区高清视频| 国产精品v片在线观看不卡| 97avcom| 国产不卡av在线免费观看| 日韩天堂在线视频| 亚洲精品99久久久久| 国产精品久久久久久久av电影| 57pao国产成人免费| 国产日韩欧美夫妻视频在线观看| 欧美与黑人午夜性猛交久久久| 欧美在线一区二区三区四| 欧美三级xxx| 亚洲欧美中文另类| 欧美成人免费在线视频| 国产在线视频欧美| 日韩视频在线免费| 久久久欧美一区二区| 国产啪精品视频| 国产精品一区二区三| 91网在线免费观看| 久久综合九色九九| 精品免费在线观看| 欧美色图在线视频| 久久在线观看视频| 久久久久中文字幕2018| 中文字幕在线视频日韩| 亚洲欧美在线免费观看| 亚洲第一免费网站| 日韩精品小视频| 亚洲摸下面视频| 欧美成aaa人片在线观看蜜臀| 91精品国产色综合久久不卡98| 亚洲新声在线观看| 日本高清久久天堂| 国产成人91久久精品| 国产丝袜一区视频在线观看| 亚洲福利视频二区| 成人中文字幕+乱码+中文字幕| 日韩成人激情在线| 日韩电影在线观看中文字幕| 欧美一区二区大胆人体摄影专业网站| 中文字幕亚洲一区二区三区五十路| 91天堂在线视频| 亚洲电影免费观看高清完整版在线观看| 国产精品视频地址| 亚洲欧洲在线观看| 日韩av网址在线观看| 亚洲国产精品yw在线观看| 亚洲资源在线看| 国内精品小视频在线观看| 日本19禁啪啪免费观看www| 一区二区三区四区视频| 国产精品老女人精品视频| 久久精品99国产精品酒店日本| 主播福利视频一区| 亚洲精品成a人在线观看| 69久久夜色精品国产7777| 国产精品国产三级国产aⅴ9色| 国产亚洲精品久久久优势| 91手机视频在线观看| 亚洲国产欧美一区二区三区久久| 久久精品99久久香蕉国产色戒| 最近中文字幕2019免费| 久久五月情影视| 欧美一级大片在线免费观看| 亚洲精品视频中文字幕| 午夜精品久久久久久久白皮肤| 久久久久久久一区二区| 国产精品99一区| 中文字幕亚洲欧美日韩2019| 国产亚洲人成网站在线观看| 韩剧1988免费观看全集| 国产精品aaaa| 亚洲va电影大全| 精品国产一区av| 成人福利视频在线观看| 欧洲成人在线观看| 日韩hd视频在线观看| 欧美极品少妇xxxxⅹ喷水| 久久免费观看视频| 久久久久99精品久久久久| 国产亚洲aⅴaaaaaa毛片| 国产精品三级网站| 国产精品 欧美在线| 国产丝袜一区二区三区免费视频| 91久久精品国产91久久性色| 久久综合久久八八| 欧美有码在线观看| 国产狼人综合免费视频| 欧美日韩国产精品专区| 日韩在线视频线视频免费网站| 高清视频欧美一级| 久久综合国产精品台湾中文娱乐网| 久久久久久综合网天天| 欧美一级成年大片在线观看| 国产极品jizzhd欧美| 精品久久久久久久久久久久久久| 欧美日韩国产精品| 91精品国产高清自在线| 影音先锋欧美在线资源| 日韩精品久久久久久福利| 欧美麻豆久久久久久中文| 成人日韩av在线| 日韩欧美精品中文字幕| 国产精品一区电影| 亚洲欧美综合图区| 亚洲免费av电影| 中文字幕视频在线免费欧美日韩综合在线看| 国产精品女视频| 欧美激情va永久在线播放| 亚洲最大中文字幕| 日韩免费在线观看视频| 91久久精品在线| 影音先锋欧美在线资源| 成人黄色av网| 亚洲精品久久久久久下一站| 91亚洲国产成人久久精品网站| 亚洲一区二区中文| 国产日产欧美精品| 日韩中文字幕在线精品| 精品高清美女精品国产区| 国产精品毛片a∨一区二区三区|国| 欧美一区二区三区免费观看| 国产精品久久精品| 亚洲色图色老头| 日韩电影中文字幕在线| 日本中文字幕不卡免费| 亚洲电影免费观看高清| 亚洲成人激情图| 日韩黄色在线免费观看| 久久综合久久美利坚合众国| 97精品视频在线播放| 琪琪第一精品导航| 国产成人aa精品一区在线播放| 色www亚洲国产张柏芝|