(function($){ $.fn.casmenu=function(argvs){ //your code }})(jQuery);其中jQuery传入的是jquery对象,需要在扩展之前引用。在扩展中同样使用jQuery的短格式$。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。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插件实现多级联动菜单效果,希望对大家的学习有所帮助。