zoukankan      html  css  js  c++  java
  • JS写的多级联select,如何取值

    var $ = function (id) {
        return "string" == typeof id ? document.getElementById(id) : id;
    };
    function addEventHandler(oTarget, sEventType, fnHandler) {
        if (oTarget.addEventListener) {
            oTarget.addEventListener(sEventType, fnHandler, false);
        } else if (oTarget.attachEvent) {
            oTarget.attachEvent("on" + sEventType, fnHandler);
        } else {
            oTarget["on" + sEventType] = fnHandler;
        }
    };
    function Each(arrList, fun){
        for (var i = 0, len = arrList.length; i < len; i++) { fun(arrList[i], i); }
    };
    function GetOption(val, txt) {
        var op = document.createElement("OPTION");
        op.value = val; op.innerHTML = txt;
        return op;
    };
    var Class = {
      create: function() {
        return function() {
          this.initialize.apply(this, arguments);
        }
      }
    }
    Object.extend = function(destination, source) {
        for (var property in source) {
            destination[property] = source[property];
        }
        return destination;
    }
    var CascadeSelect = Class.create();
    CascadeSelect.prototype = {
      //select集合,菜单对象
      initialize: function(arrSelects, arrMenu, options) {
        if(arrSelects.length <= 0 || arrMenu.lenght <= 0) return;//菜单对象
        var oThis = this;
        this.Selects = [];//select集合
        this.Menu = arrMenu;//菜单对象    
        this.SetOptions(options);    
        this.Default = this.options.Default || [];    
        this.ShowEmpty = !!this.options.ShowEmpty;
        this.EmptyText = this.options.EmptyText.toString();
        
        //设置Selects集合和change事件
        Each(arrSelects, function(o, i){
            addEventHandler((oThis.Selects[i] = $(o)), "change", function(){ oThis.Set(i); });
        });   
        this.ReSet();
      },
      //设置默认属性
      SetOptions: function(options) {
        this.options = {//默认值
            Default:    [],//默认值(按顺序)
            ShowEmpty:    false,//是否显示空值(位于第一个)
            EmptyText:    "请选择"//空值显示文本(ShowEmpty为true时有效)
        };
        Object.extend(this.options, options || {});
      },
      //初始化select
      ReSet: function() { 
        this.SetSelect(this.Selects[0], this.Menu, this.Default.shift());
        this.Set(0);
      },
      //全部select设置
      Set: function(index) {
        var menu = this.Menu  
        //第一个select不需要处理所以从1开始
        for(var i=1, len = this.Selects.length; i < len; i++){
            if(menu.length > 0){
                //获取菜单
                var value = this.Selects[i-1].value;
                if(value!=""){
                    Each(menu, function(o){ if(o.val == value){ menu = o.menu || []; } });
                } else { menu = []; }         
                //设置菜单
                if(i > index){ this.SetSelect(this.Selects[i], menu, this.Default.shift()); }
            } else {
                //没有数据
               this.SetSelect(this.Selects[i], [], "");
            }
        }
        //清空默认值
        this.Default.length = 0;
      },
      //select设置
      SetSelect: function(oSel, menu, value) {
        oSel.options.length = 0; oSel.disabled = false;
        if(this.ShowEmpty){ oSel.appendChild(GetOption("", this.EmptyText)); }
        if(menu.length <= 0){ oSel.disabled = true; return; }    
        Each(menu, function(o){
            var op = GetOption(o.val, o.txt ? o.txt : o.val); op.selected = (value == op.value);
            oSel.appendChild(op);
        });    
      },
      //添加菜单
      Add: function(menu) {
        this.Menu[this.Menu.length] = menu;
        this.ReSet();
      },
      //删除菜单
      Delete: function(index) {
        if(index < 0 || index >= this.Menu.length) return;
        for(var i = index, len = this.Menu.length - 1; i < len; i++){ this.Menu[i] = this.Menu[i + 1]; }
        this.Menu.pop()
        this.ReSet();
      }
    };
    window.onload=function(){
        var menu = [
            
            {'val': '广西自治区', 'menu': [
                {'val': '梧州市', 'menu': [
                    {'val': '万秀区','menu':[
                     {'val':'选择街道'},
                     {'val':'富民街道','menu':[
                     {'val':'选择社区'},
                     {'val':'富康社区'},
                     {'val':'富安社区'}]},
                     {'val':'东兴街道','menu':[
                     {'val':'选择社区'},
                     {'val':'香樟社区'},
                     {'val':'月桂社区'}]},
                     {'val':'角嘴街道','menu':[
                     {'val':'选择社区'},
                     {'val':'蓝天社区'},
                     {'val':'塘源社区'}]},
                     {'val':'城北街道','menu':[
                     {'val':'选择社区'},
                     {'val':'华机社区'},
                     {'val':'桂北社区'}]},
                     {'val':'城中街道','menu':[
                     {'val':'选择社区'},
                     {'val':'冰泉社区'},
                     {'val':'四坊社区'}]}]}
                ]}
            ]}
        ];
        var sel=["sel1", "sel2", "sel3", "sel4", "sel5"];
        var val=["广西自治区"];
        var cs = new CascadeSelect(sel, menu, { Default: val });
    };

  • 相关阅读:
    结对编程1-基于GUI的四则运算生成器
    个人作业1——四则运算题目生成程序(基于控制台)
    软件工程的实践项目课程的自我目标
    个人作业3——个人总结(Alpha阶段)
    结对编程2——单元测试
    个人作业(2)---英语学习APP案例分析
    结对作业1----基于GUI的四则运算生成器
    个人作业1——四则运算题目生成程序(基于控制台)
    个人作业3——个人总结(Alpha阶段)
    结对编程2——单元测试
  • 原文地址:https://www.cnblogs.com/momjs/p/5896480.html
Copyright © 2011-2022 走看看