• js动态获取子复选项并设计全选及提交


     在做项目的时候,会遇到根据父选项,动态的获取子选项,并列出多个复选框,提交时,把选中的合并成一个字符提交后台

    本章将讲述如何通过js控制实现该操作:

    1:设计父类别为radio,为每一个radio都加上onclick事件,并默认类别1为选择状态。

    <input type="checkbox" name="selectall" id="selectall" onClick="selectAll();" checked="checked"/>全选<br>
    <input type="radio" name="lb" id="lb" value="1" onclick="getZlb(1);" checked="checked"/>类别1
    <input type="radio" name="lb" id="lb" value="2" onclick="getZlb(2);"/>类别2
    <input type="radio" name="lb" id="lb" value="3" onclick="getZlb(3);"/>类别3

    2:页面初加载时,要根据选中的父类别显示子类别,在点击按钮时,也要获取子类别,故写成同一个方法,并在页面加载结束后调用

    window.onload=getZlb();

    3:获取子类别的js方法,通过ajax方法动态获取后台数据

    /**
     * 获取子类别,在页面加载结束后也执行显示
     */
      function getZlb(){
        //通过名字获取
        var obj = document.getElementsByName("lb");
            for(var i=0; i<obj.length; i ++){
                if(obj[i].checked){
                    getZlbNews(obj[i].value);
                }
        }
      }
    
    function getZlbNews(){
           (通过Ajax获取map类型的数据;返回数据为result,json格式)
           var json = eval("("+result+")");  //转化为json对象
            //通过ID获取子类型要显示的区域
           var parent=document.getElementById('xsqy');
           //把子区域置空,防止下次追加
           parent.innerHTML='';
           var p=0;
           var span="";
           //把全选打上勾
           document.getElementById("selectall").checked=true;
           for(var i in json){
             p++;
             span="<SPAN style="display:inline-block;  75px;"><input type="checkbox" checked="checked" onClick="checkSelectAll();" name="zlb" value=""+i+"">"+json[i]+"</SPAN>";
             //当子复选框超过11个,则换行
             if(p%11==0){
                 span=span+"<br>";
             }
             //把子复选框一个个追加到子区域
             parent.innerHTML=parent.innerHTML+span;
           } 
    }        

    4:后台逻辑,

      /**
         * 通过子类别,返回Map格式 Map<代码,名称>
         * @return
         */
        public String getZLb(){
            Map<Integer, String> zlb=service.getZLB();
            //把map转化为json格式
            JSON a= JSONSerializer.toJSON(zlb);
            return a.toString();
        }

    5:js控制全选,及全选是否选中的逻辑,及提交时如何合并选中的代码

    /**
       * 全选或是全部取消
       */
      function selectAllDz(){
          var checkboxs = document.getElementsByName("zlb");
          for(var i=0; i<checkboxs.length; i++) {
          //根据全选的按钮是否选中来控制子类别是否选中
              checkboxs[i].checked = document.getElementById("selectall").checked;
          }
      }
    /**
     * 判断子类别是否全选,是全选则全选按钮选中,否则不选中
     */
      function checkSelectAll(){
          var checkboxs = document.getElementsByName("zlb");
          var isSelectAll=true;
          for(var i=0; i<checkboxs.length; i++) {
              if(checkboxs[i].checked ==false){
                  isSelectAll=false;
              }
          }
          if(isSelectAll==false){
              document.getElementById("selectall").checked=false;
          }else{
              document.getElementById("selectall").checked=true;
          }
      }
    /**
    * 拼接选中的ID,以逗号分隔
    **/
    function getAllIdStr(checkName){
        var select = document.getElementsByName(checkName);
         var idStr = new Array();
         for(var i=0; i<select.length; i++){
             if(select[i].checked==true){
                 idStr = idStr.concat(select[i].value);
             }
         }
         return idStr.join(',');
    }

     6:在进行下一步操作时,如提交时,把全选的变成一个字符,赋值给一个隐藏的文本框,用来提交到后台

    //调用拼接ID的方法,把要操作的元素名字传过去
    var allZlb=getAllIdStr('zlb');
    //创建一个隐藏的文本框,把拼接后的赋之,用于后台获取
    document.getElementById('allZlbStr').value=allZlb;

    以上只是个人拙见,如有更好的处理建议,请告知

    over

  • 相关阅读:
    ASP.NET Core管道详解[4]: 中间件委托链
    从执行上下文角度重新理解.NET(Core)的多线程编程[3]:安全上下文
    从执行上下文角度重新理解.NET(Core)的多线程编程[2]:同步上下文
    从执行上下文角度重新理解.NET(Core)的多线程编程[1]:基于调用链的”参数”传递
    ASP.NET Core管道详解[3]: Pipeline = IServer + IHttpApplication
    ASP.NET Core管道详解[2]: HttpContext本质论
    ASP.NET Core应用基本编程模式[5]:如何放置你的初始化代码
    如何实现Http请求报头的自动转发[设计篇]
    如何实现Http请求报头的自动转发[应用篇]
    采用”传统”方式获取当前HttpContext
  • 原文地址:https://www.cnblogs.com/sky-/p/5611479.html
Copyright © 2020-2023  润新知