作家
登录

javascript 三级下拉选择菜单Levels对象

作者: 来源:www.28hudong.com 2013-03-30 02:27:47 阅读 我要评论

JavaScript: 复制代码 代码如下: <script type="text/javascript"> var level1 = ["Beijing", "GuangZhou", "ShangHai"]; var level2 = [["ZhaoYang", "TianTan", "GuGong"], ["Tianhe", "Panyu"], ["PuDong", "PuXi"]]; var level3 = [[["TianShan", "HuangShan"], ["TianTan1", "TianTan2"], ["GuGong1", "GuGong2", "GuGong3", "GuGong4"]], [["TianHe1", "TianHe2"], ["PanYu1", "PanYu2"]], [["PuDong1", "PuDong2"], ["PuXi1", "PuXi2"]]]; var Levels = { fL: null,//用存储各级select的DOM引用 sL: null, tL: null, l1: null, l2: null, l3: null, $: function(id){ return (typeof id == "object") ? id : document.getElementById(id); }, init: function(fID, sID, tID, l1, l2, l3){ this.fL = this.$(fID); this.sL = this.$(sID); this.tL = this.$(tID); this.l1 = l1; this.l2 = l2; this.l3 = l3; this.fL.options.add(new Option("Select",-1));//给一级菜单添加一个“select”标志 for (var i = 0; i < l1.length; i++) { var item = new Option(l1[i], i); this.fL.options.add(item); } this.doLev2(); //调用doLev2函数,处理二级菜单 this.doLev3(); //调用doLev3函数,处理三级菜单 }, removeSTL: function(){ //用于删除第二、三级的菜单项 this.sL.options.length = 0; this.tL.options.length = 0; }, removeTL: function(){ //用于删除第三级的菜单项 this.tL.options.length = 0; }, doLev2: function(){ //处理二级菜单 var that = this; this.fL.onchange = function(){ that.removeSTL(); //删除旧second的select if (that.fL.selectedIndex == 0) { that.removeSTL(); // //删除旧second的select } else { that.sL.options.add(new Option("Select", -1)); //给二级菜单添加一个“select”标志 //获取第二级所需的数组 var items = that.l2[that.fL.selectedIndex - 1]; for (var i = 0; i < items.length; i++) { //添加第二级的新select项 var item = new Option(items[i], i); that.sL.options.add(item); } } } }, doLev3: function(){ //处理三级菜单 var that = this; this.sL.onchange = function(){ that.removeTL(); //删除旧third的select if (that.sL.selectedIndex == 0) { that.removeTL(); //删除旧third的select } else { that.tL.options.add(new Option("Select", -1)); //给三级菜单添加一个“select”标志 //获取第三级所需的数组 var items = that.l3[that.fL.selectedIndex - 1][that.sL.selectedIndex - 1]; for (var i = 0; i < items.length; i++) { //添加第三级的新select项 var item = new Option(items[i], i); that.tL.options.add(item); } } } } } onload = function(){ Levels.init("first", "second", "third", level1,level2,level3); //调用Levels的init方法 } </script> HTML: 复制代码 代码如下: <form> <select id="first"> </select> <select id="second"> </select> <select id="third"> </select> </form> 演示代码: Untitled Document [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

  推荐阅读

  JQuery 学习笔记 选择器之三

复制代码 代码如下: <!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 >>>详细阅读


本文标题:javascript 三级下拉选择菜单Levels对象

地址:http://www.17bianji.com/kaifa2/JS/28392.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)