你的位置:首页 > Java教程

[Java教程]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; width: 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