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

首頁 > 編程 > JavaScript > 正文

jQuery插件實現多級聯動菜單效果

2019-11-20 11:07:00
字體:
來源:轉載
供稿:網友

開發中,有好多地方用到聯動菜單,以前每次遇到聯動菜單的時候都去重新寫,代碼重用率很低,前幾天又遇到聯動菜單的問題,總結了下,發現可以開發一個聯動菜單的功能,以后想用的時候就方便多了。項目中每個頁面都有引用jQuery,,開發個jQuery聯動菜單插件,說動手就動手,下面跟大家分享分享。

我用的jQuery插件方式

(function($){ $.fn.casmenu=function(argvs){   //your code }})(jQuery);

其中jQuery傳入的是jquery對象,需要在擴展之前引用。在擴展中同樣使用jQuery的短格式$。

$.fn是指jquery的命名空間,加在fn上的方法及屬性,會對jquery實例每一個有效,看看下面的jquery源碼101行左右:

jQuery.fn = jQuery.prototype = { ......}

比如說后面要開發的$.fn.casmenu(),定義之后,在后面的jquery對象都可以使用該方法。

這里還有一種擴展的方法:

$.extend({ funName: function(){  //your code },});

這種擴展方法和上面的是有區別的,要是拿類做類比的話,$.extend這種方法相當于類中的靜態方法,上面的一種方式相當于非靜態方法,必須有對象才可以使用。簡單的理解,是下面這樣的:

//$.fn.casemenu 方式擴展的方法,必須在有jquery對象的時候才可以使用$("#mydiv").casmenu();//$.extend({}) 方式擴展的方法,可以直接使用$.add(2,3);

設計思路
首先是層級菜單的數據保存方式,看看下面的數據:

var levels={ //內容中有引號,必須使用單引號,外引號必須用雙引號 //name => value 1:{  退出應用: "code1003",  登錄界面:"code1004",  跳轉至個人資料界面:"code1005", }, 2:{  退出應用:{   應用1:"gameid1",   應用2:"gameid2",   應用3:"gameid3",   應用4:"gameid4",   應用5:"gameid5",     },  跳轉至個人資料界面:{   主界面:"main interface",  } }, 3:{  應用1:{   中級場:"12",   高級場:"13",   職業場:"14",   比賽場:"15",  } }}

對象levels中的直接鍵值1、2、3代表菜單的層級,沒有就不用些,每一項name=>value代表select中option的名稱和value。

層級有規律,某一層級中的某一項要是有下一級菜單,在下一層及有該項的名稱,就像levels[1]['退出應用']在有下級菜單,就有levels[2]['退出應用'],要是繼續有下級菜單,就像levels[2]['退出應用']['應用1'],會在下一層及中繼續有levels[3]['應用1']。這樣一來,就實現了無限級聯動菜單,不同的聯動菜單只需要修改菜單配置文件就可以了。

但是這么做又有一個遺憾,就是如果level2[2]中的子項有兩個名稱相同的,都有下級菜單,而且下級菜單內容還不一樣,就會有問題,因此在設置的時候,有下級菜單的項要取不同的名稱,這里要注意下。就目前這種來說,簡單,好理解,也夠用了。

代碼實現
在代碼中也用到了$.extend,用來擴展默認配置。

還有一個點要注意,在聯動的時候會將實事的菜單值放入一個屬性為hidden的input中,用默認逗號分割每個層級之間的值,可以很輕松的獲取到聯動菜單所有項的值

if(typeof(AI.opts.saveinput) != "undefined" && (AI.opts.saveinput = AI.opts.saveinput.toString()) != ''){   $("<input type='hidden' value='' name='"+AI.opts.saveinput+"' id='"+AI.opts.saveinput+"' />").appendTo($('body'));  }

(function($){ //配置 var AI={  opts:{   saveinput:"jumpcode", //是否將結果保存至input   levels:{},   ulObj:{},//保存生成好的ul列表   length:0, //層級菜單的層級   divide:",",//默認各個層級菜單之間的分隔符  } }; $.fn.casmenu=function(opts){  AI.opts = $.extend(AI.opts, opts);  if((AI.opts.length = Object.keys(AI.opts.levels).length) <= 0){   throw "levels arr must not be empty";   return;  }  var _levels = AI.opts.levels;  if(_levels[1] == undefined){   throw "menu level 1 must not be empty";   return;  }  var _levels_1 = _levels[1];  if(typeof(AI.opts.saveinput) != "undefined" && (AI.opts.saveinput = AI.opts.saveinput.toString()) != ''){   $("<input type='hidden' value='' name='"+AI.opts.saveinput+"' id='"+AI.opts.saveinput+"' />").appendTo($('body'));  }  AI.opts.ulObj['level_1'] = '<select class="casmenu" level="1">';  AI.opts.ulObj['level_1'] += '<option value="null">請選擇</option>';  $("#"+AI.opts.saveinput).val('null');  for(var i in _levels_1){   AI.opts.ulObj['level_1'] += '<option name="'+i+'" value="'+_levels_1[i]+'">'+i+'</option>';  }  AI.opts.ulObj['level_1'] += '</select>';  $(AI.opts.ulObj['level_1']).appendTo(this);  $("body").on("change", ".casmenu", function(){   var level = $(this).attr("level");   if(level > AI.opts.length) return;   level++;   //移除當前觸發菜單之后的菜單   for(var num=level;num<=AI.opts.length;num++){    $(".casmenu[level="+num+"]").remove();   }   //設置input的值,級聯菜單的值   var _val = '';   for(var val=1;val<=AI.opts.length;val++){    var __val = $("select[level="+val+"]");    if(__val.length <= 0)     continue;    _val += __val.val()+AI.opts.divide;   }   $("#"+AI.opts.saveinput).val(_val.substr(0, _val.length-1));   //levels對象中不存在下一級別目錄   if(typeof(AI.opts.levels[level]) == "undefined") return;   //獲取下一級別目錄的鍵值,值不存在的話返回   var name = $(this).find("option:selected").attr("name");   if(typeof(AI.opts.levels[level][name]) == "undefined") return;   if(typeof(AI.opts.ulObj['level_'+level]) == "undefined" || typeof(AI.opts.ulObj['level_'+level][name]) == "undefined"){    if(typeof(AI.opts.ulObj['level_'+level]) == "undefined")     AI.opts.ulObj['level_'+level] = {};    AI.opts.ulObj['level_'+level][name] = '<select class="casmenu" level="'+level+'">';    AI.opts.ulObj['level_'+level][name] += '<option value="null">請選擇</option>';    var levelinfo = AI.opts.levels[level][name];    for(var i in levelinfo){     AI.opts.ulObj['level_'+level][name] += '<option name="'+i+'" value="'+levelinfo[i]+'" >'+i+'</option>';    }    AI.opts.ulObj['level_'+level][name] += '</select>';   }   $(AI.opts.ulObj['level_'+level][name]).appendTo($(this).parent());   var _val = '';   for(var val=1;val<=AI.opts.length;val++){    var __val = $("select[level="+val+"]");    if(__val.length <= 0)     continue;    _val += __val.val()+AI.opts.divide;   }   $("#"+AI.opts.saveinput).val(_val.substr(0, _val.length-1));  }); }})(jQuery);

運行效果:

以上就是為大家分享的jQuery插件實現多級聯動菜單效果,希望對大家的學習有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
狠狠躁夜夜躁久久躁别揉| 亚洲影视中文字幕| 亚洲天堂男人的天堂| 国产精品日日摸夜夜添夜夜av| 91手机视频在线观看| 亚洲第一精品福利| 日韩成人av在线| 久久久精品一区二区| 亚洲欧美成人一区二区在线电影| 在线电影欧美日韩一区二区私密| 欧美成年人在线观看| 黄色91在线观看| 久久男人av资源网站| 亚洲国产精品中文| 亚洲欧洲一区二区三区久久| 亚洲成人久久久| 国产精品一区二区性色av| 亚洲自拍偷拍色片视频| 成人做爰www免费看视频网站| 久久久久中文字幕| 日韩免费看的电影电视剧大全| 亚洲第一页中文字幕| 欧美猛交免费看| 久久精品亚洲一区| 96精品久久久久中文字幕| 97福利一区二区| 亚洲精品国产精品久久清纯直播| 国产成人精品免费视频| 亚洲肉体裸体xxxx137| 日韩精品极品视频| 亚洲国产成人在线播放| 午夜伦理精品一区| 国产区精品在线观看| 2019中文字幕在线免费观看| 国产精品自拍偷拍视频| 正在播放欧美视频| 青青在线视频一区二区三区| 国产精品视频大全| 国产日韩欧美另类| 日韩免费在线视频| 欧美在线一级va免费观看| 91视频国产高清| 亚洲天堂男人天堂女人天堂| 亚洲国产精品久久久久秋霞不卡| 国产精品爱久久久久久久| 国内精品美女av在线播放| 久久久久久高潮国产精品视| 国产欧美日韩最新| 国产日韩在线观看av| 欧美午夜美女看片| 午夜精品久久久久久久白皮肤| 久久久成人精品| 欧美尤物巨大精品爽| 亚洲欧美日韩久久久久久| 欧美午夜电影在线| 久久久www成人免费精品| 韩国福利视频一区| 97超级碰碰碰| 欧美又大又粗又长| 按摩亚洲人久久| 亚洲自拍高清视频网站| 亚洲国产精品字幕| 亚洲免费视频观看| 超碰精品一区二区三区乱码| 久久久天堂国产精品女人| 国产精品久久精品| 亚洲天堂第一页| 亚洲第一区中文99精品| 久久久久久久久久国产| 精品视频在线观看日韩| 国产精品久久久久久久天堂| 亚洲欧美国产视频| 成人写真视频福利网| 日韩美女福利视频| 日韩欧美福利视频| 亚洲成人免费在线视频| 日韩欧美精品免费在线| 亚洲sss综合天堂久久| 亚洲激情免费观看| 欧洲精品在线视频| 久久精品亚洲94久久精品| 日韩中文字幕免费| 亚洲女人天堂色在线7777| 亚洲在线一区二区| 国产精品自拍网| 亚洲成人av在线| www.日韩av.com| 亚洲激情在线观看视频免费| 国产在线高清精品| 国产拍精品一二三| 中文字幕成人精品久久不卡| 色偷偷91综合久久噜噜| 欧美三级xxx| 琪琪亚洲精品午夜在线| 亚洲精品少妇网址| 国模精品视频一区二区| 九九热最新视频//这里只有精品| 7m第一福利500精品视频| 日韩精品在线影院| 色妞色视频一区二区三区四区| 欧美成人午夜激情视频| 精品亚洲男同gayvideo网站| 精品视频中文字幕| 国产香蕉一区二区三区在线视频| 高清亚洲成在人网站天堂| 精品国产电影一区| 国产精品高潮粉嫩av| 中文字幕精品一区二区精品| 久久精品91久久香蕉加勒比| 欧美日韩美女在线| 久久视频这里只有精品| 狠狠色香婷婷久久亚洲精品| 久久久亚洲国产天美传媒修理工| 国产精品视频自在线| 中文字幕精品在线| 国产精品一区二区3区| 成人国产精品一区| 日韩一级裸体免费视频| 久久久免费电影| 91精品视频在线看| 国产精品综合久久久| 国产精品老牛影院在线观看| 亚洲欧洲成视频免费观看| 国产精品av电影| 欧美一性一乱一交一视频| 亚洲新声在线观看| 久久精品亚洲94久久精品| 亚洲精品自拍视频| 国产美女直播视频一区| 欧美福利视频在线| 亚洲午夜未满十八勿入免费观看全集| 亚洲色图在线观看| 久久国产精品久久久久| 欧美亚洲成人精品| 欧美美女操人视频| 精品成人乱色一区二区| 伊人伊成久久人综合网小说| 久久久av免费| 欧美午夜久久久| 国产精品久久久久久久久久尿| 亚洲精品久久久久国产| 国产精品一久久香蕉国产线看观看| 国模精品系列视频| 91精品国产高清自在线看超| 国产精品吹潮在线观看| 亚洲国产精品中文| 两个人的视频www国产精品| 国产亚洲激情视频在线| 国产精品成人品| 亚洲第一中文字幕| 亚洲精品国产精品久久清纯直播| 国产精品三级在线| 日韩一区av在线| 久久精品亚洲94久久精品| 久久久久久久国产精品| 欧美在线不卡区| 国产精品视频一区二区高潮| 色妞色视频一区二区三区四区| 亚洲资源在线看| 成人xvideos免费视频| 国产精品一区专区欧美日韩| 亚洲综合日韩在线| 欧美成人精品在线视频| 国产亚洲欧美日韩一区二区|