javascript实现无限级select联动菜单


Posted in Javascript onJanuary 02, 2015

代码很简单,这里主要是给大家推荐一下本代码的实现思路,别具一格。

奉上代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>Selects</title>

<style type="text/css">

*{font-size:14px;}

select{height:20px;font-size:12px;}

</style> 

</head>

<body >

<div style='color:red'>2级联动</div>

<div id='demo1'></div><br><br><br>

<div style='color:red'>3级联动</div>

<div id='demo2'></div><br><br><br>

<div style='color:red'>4级联动</div>

<div id='demo3'></div><br><br><br>

<div style='color:red'>5级联动</div>

<div id='demo4'></div><br><br><br>

<script language="javascript">

var Sys = (function(ua){

  var s = {};

  s.IE = ua.match(/msie ([\d.]+)/)?true:false;

  s.Firefox = ua.match(/firefox\/([\d.]+)/)?true:false;

  s.Chrome = ua.match(/chrome\/([\d.]+)/)?true:false;

  s.IE6 = (s.IE&&([/MSIE (\d)\.0/i.exec(navigator.userAgent)][0][1] == 6))?true:false;

  s.IE7 = (s.IE&&([/MSIE (\d)\.0/i.exec(navigator.userAgent)][0][1] == 7))?true:false;

  s.IE8 = (s.IE&&([/MSIE (\d)\.0/i.exec(navigator.userAgent)][0][1] == 8))?true:false;

  return s;

})(navigator.userAgent.toLowerCase());

Sys.IE6&&document.execCommand("BackgroundImageCache", false, true); 

function $(Id){

  return document.getElementById(Id);

};

function $$(p,e){

  return p.getElementsByTagName(e);

};

function addListener(element,e,fn){

  element.addEventListener?element.addEventListener(e,fn,false):element.attachEvent("on" + e,fn);

};

function removeListener(element,e,fn){

  element.removeEventListener?element.removeEventListener(e,fn,false):element.detachEvent("on" + e,fn);

};

var Bind = function(object, fun) {

  var args = Array.prototype.slice.call(arguments).slice(2);

  return function() {

    return fun.apply(object, args);

  };

};

var BindAsEventListener = function(object, fun) {

  var args = Array.prototype.slice.call(arguments).slice(2);

  return function(event) {

    return fun.apply(object, [event || window.event].concat(args));

  };

};

var Extend = function(destination, source){

  for (var property in source) {

    destination[property] = source[property];

  };

};

var Class = function(properties){

  var _class = function(){return (arguments[0] !== null && this.initialize && typeof(this.initialize) == 'function') ? this.initialize.apply(this, arguments) : this;};

  _class.prototype = properties;

  return _class;

};
//==========================================================================================================================

var Selects = new Class({

 initialize :function(container,data,title){

  this.container  = container;

  this.num = title.length;

  this.Events = new Array(title.length-1);

  var i,l,select;

  for(i=0; i<this.num ; i++)

  {

   container.innerHTML = container.innerHTML + " " + title[i];

   container.appendChild(document.createElement('select'));

  }

  select = $$(container,'select')[0];

  for(i=0,l=data.length;i<l;i++)

   select.options.add(new Option(data[i].txt,i)); 

  addListener(select,'change',Bind(this,this.Change,select,data,0));

  this.Change(select,data,0);

 },

 Change : function(obj,data,num){

  if(num == this.num-1)return;  

  var menu = data[obj.value].menu;

  select = $$(this.container,'select')[num+1];

  select.length = 0;  

  if(!menu)return;

  if(this.Events[num]!=undefined)removeListener(select,'change',this.Events[num])

  this.Events[num] = Bind(this,this.Change,select,menu,num+1)

  addListener(select,'change',this.Events[num]);  

  for(var i=0,l=menu.length;i<l;i++)

   select.options.add(new Option(menu[i].txt,i));

  this.Change(select,menu,num+1); 

 }

});
//==========================================================================================================================

window.onload = function(){

 var data=[{"txt":"人族","menu":[{"txt":"大法师","menu":[{"txt":"大法技能","menu":[{"txt":"水元素","menu":[{"txt":"召唤物"},{"txt":"穿刺攻击"},{"txt":"很好东西"}]},{"txt":"暴风雪","menu":[{"txt":"魔法攻击"},{"txt":"面积伤害"},{"txt":"很漂亮"},{"txt":"可被打断"}]},{"txt":"辉煌光环"},{"txt":"瞬间移动"}]},{"txt":"英雄说明","menu":[{"txt":"智力英雄"},{"txt":"强大光环"},{"txt":"辅助型"},]}]},{"txt":"山丘之王","menu":[{"txt":"山丘技能","menu":[{"txt":"风暴之锤"},{"txt":"锥地"},{"txt":"锥晕"},{"txt":"天神下凡"}]},{"txt":"英雄说明","menu":[{"txt":"力量英雄"},{"txt":"秒杀能力"},{"txt":"个子很矮"},{"txt":"大技变态"}]}]},{"txt":"圣骑士","menu":[{"txt":"圣骑技能","menu":[{"txt":"光"},{"txt":"无敌"},{"txt":"光环"},{"txt":"复活"}]},{"txt":"英雄说明","menu":[{"txt":"力量英雄"},{"txt":"辅助英雄"},{"txt":"人称奶妈"}]}]},{"txt":"血法师","menu":[{"txt":"血法技能","menu":[{"txt":"火焰"},{"txt":"吸蓝"},{"txt":"虚无"},{"txt":"神鸟凤凰"}]},{"txt":"英雄说明","menu":[{"txt":"智力英雄"},{"txt":"辅助英雄"},{"txt":"长的很帅"}]}]}]},{"txt":"兽族","menu":[{"txt":"贱圣","menu":[{"txt":"贱圣技能","menu":[{"txt":"疾风步"},{"txt":"影分身"},{"txt":"致命一击"},{"txt":"剑刃风暴"}]},{"txt":"英雄说明","menu":[{"txt":"敏捷英雄"},{"txt":"高攻英雄"},{"txt":"杀人越货"},{"txt":"猥亵无敌"},{"txt":"非常强大"}]}]},{"txt":"先知男","menu":[{"txt":"先知技能","menu":[{"txt":"狼"},{"txt":"日"},{"txt":"闪电链"},{"txt":"地震"}]},{"txt":"英雄说明","menu":[{"txt":"智力英雄"},{"txt":"骚扰英雄"}]}]},{"txt":"牛头人酋长","menu":[{"txt":"牛头技能","menu":[{"txt":"冲击波"},{"txt":"阵地"},{"txt":"耐久光环"},{"txt":"复活"}]},{"txt":"英雄说明","menu":[{"txt":"力量英雄"},{"txt":"魔法强大"},{"txt":"长的威猛"},{"txt":"一个肉盾"}]}]},{"txt":"小YY","menu":[{"txt":"小Y技能","menu":[{"txt":"变动物"},{"txt":"治疗波"},{"txt":"小蛇棒子"},{"txt":"全体无敌"}]},{"txt":"英雄说明","menu":[{"txt":"敏捷英雄"},{"txt":"魔法强大"},{"txt":"辅助英雄"}]}]}]},{"txt":"不死族","menu":[{"txt":"死亡骑士","menu":[{"txt":"亡骑技能","menu":[{txt:"大便一拓"},{txt:"邪恶光环"},{txt:"死亡契约"},{txt:"复活亡灵"}]},{"txt":"英雄说明","menu":[{txt:"骑的是羊"},{txt:"未老先衰"},{txt:"冰霜之哀"},{txt:"啊而塞思"}]}]},{"txt":"巫妖","menu":[{"txt":"巫妖技能","menu":[{txt:"暴冰"},{txt:"冰甲"},{txt:"契约"},{txt:"死亡凋零"}]},{"txt":"英雄说明","menu":[{txt:"穿裙子"},{txt:"全是骨头"},{txt:"不男不女"}]}]},{"txt":"恐惧魔王","menu":[{"txt":"魔王技能"},{"txt":"英雄说明"}]},{"txt":"小强王子","menu":[{"txt":"王子技能"},{"txt":"英雄说明"}]}]}];

 new Selects($('demo1'),data,["种族","英雄"]);

 new Selects($('demo2'),data,["种族","英雄","介绍"]);

 new Selects($('demo3'),data,["种族","英雄","介绍","技能"]);

 new Selects($('demo4'),data,["种族","英雄","介绍","技能","技能说明"]);

}

</script>

</body>

</html>

Javascript 相关文章推荐
jQuery 浮动导航菜单适合购物商品类型的网站
Sep 09 Javascript
js实现TAB切换对应不同颜色的代码
Aug 31 Javascript
javascript cookie用法基础教程(概念,设置,读取及删除)
Sep 20 Javascript
JavaScript中数组slice和splice的对比小结
Sep 22 Javascript
javascript实现根据函数名称字符串动态执行函数的方法示例
Dec 28 Javascript
mongoose中利用populate处理嵌套的方法
May 26 Javascript
在vue项目中,将juery设置为全局变量的方法
Sep 25 Javascript
JavaScript数据结构与算法之基本排序算法定义与效率比较【冒泡、选择、插入排序】
Feb 21 Javascript
Vue监听页面刷新和关闭功能
Jun 20 Javascript
微信小程序-API接口安全详解
Jul 16 Javascript
Vue+Typescript中在Vue上挂载axios使用时报错问题
Aug 07 Javascript
javascript设计模式 ? 抽象工厂模式原理与应用实例分析
Apr 09 Javascript
javascript实现表格排序 编辑 拖拽 缩放
Jan 02 #Javascript
原生javascript实现DIV拖拽并计算重复面积
Jan 02 #Javascript
javascript使用smipleChart实现简单图表
Jan 02 #Javascript
原生javascript实现简单的datagrid数据表格
Jan 02 #Javascript
浅谈jQuery事件绑定原理
Jan 02 #Javascript
js+jquery实现图片裁剪功能
Jan 02 #Javascript
javascript 构造函数方式定义对象
Jan 02 #Javascript
You might like
PHP随机生成随机个数的字母组合示例
2014/01/14 PHP
php中ftp_chdir与ftp_cdup函数用法
2014/11/18 PHP
YII Framework框架教程之日志用法详解
2016/03/14 PHP
php文件上传及下载附带显示文件及目录功能
2017/04/27 PHP
php在windows环境下获得cpu内存实时使用率(推荐)
2018/02/08 PHP
Laravel框架实现多数据库连接操作详解
2019/07/12 PHP
又一个图片自动缩小的JS代码
2007/03/10 Javascript
来自chinaz的ajax获取评论代码
2008/05/03 Javascript
IE6 弹出Iframe层中的文本框“经常”无法获得输入焦点
2009/12/27 Javascript
jQuery中使用Ajax获取JSON格式数据示例代码
2013/11/26 Javascript
一个js导致的jquery失效问题的解决方法
2013/11/27 Javascript
JS中Location使用详解
2015/05/12 Javascript
使用requestAnimationFrame实现js动画性能好
2015/08/06 Javascript
javascript入门之window对象【新手必看】
2016/11/22 Javascript
几种tab切换详解
2017/02/03 Javascript
nodejs简单读写excel内容的方法示例
2018/03/16 NodeJs
webpack中如何加载静态文件的方法步骤
2019/05/18 Javascript
JavaScript编写开发动态时钟
2020/07/29 Javascript
OpenLayers3实现对地图的基本操作
2020/09/28 Javascript
Python与Redis的连接教程
2015/04/22 Python
python中字典(Dictionary)用法实例详解
2015/05/30 Python
python 采集中文乱码问题的完美解决方法
2016/09/27 Python
python实现扫描局域网指定网段ip的方法
2019/04/16 Python
pyqt 多窗口之间的相互调用方法
2019/06/19 Python
在Pandas中处理NaN值的方法
2019/06/25 Python
Python 类方法和实例方法(@classmethod),静态方法(@staticmethod)原理与用法分析
2019/09/20 Python
jupyter notebook清除输出方式
2020/04/10 Python
matplotlib基础绘图命令之bar的使用方法
2020/08/13 Python
CSS+jQuery+PHP+MySQL实现的在线答题功能
2015/04/25 HTML / CSS
爱游人:Travelliker
2017/09/05 全球购物
adidas马来西亚官网:adidas MY
2020/09/12 全球购物
军训自我鉴定
2014/01/22 职场文书
村级换届选举方案
2014/05/10 职场文书
银行委托书范本
2014/09/28 职场文书
入股合作协议书
2014/10/12 职场文书
2015年学雷锋活动总结
2015/02/06 职场文书