js动态获取子复选项并设计全选及提交的实现方法
在做项目的时候,会遇到根据父选项,动态的获取子选项,并列出多个复选框,提交时,把选中的合并成一个字符提交后台
本章将讲述如何通过js控制实现该操作:
1:设计父类别为radio,为每一个radio都加上onclick事件,并默认类别1为选择状态。
<inputtype="checkbox"name="selectall"id="selectall"onClick="selectAll();"checked="checked"/>全选<br> <inputtype="radio"name="lb"id="lb"value="1"onclick="getZlb(1);"checked="checked"/>类别1 <inputtype="radio"name="lb"id="lb"value="2"onclick="getZlb(2);"/>类别2 <inputtype="radio"name="lb"id="lb"value="3"onclick="getZlb(3);"/>类别3
2:页面初加载时,要根据选中的父类别显示子类别,在点击按钮时,也要获取子类别,故写成同一个方法,并在页面加载结束后调用
window.onload=getZlb();
3:获取子类别的js方法,通过ajax方法动态获取后台数据
/**
*获取子类别,在页面加载结束后也执行显示
*/
functiongetZlb(){
//通过名字获取
varobj=document.getElementsByName("lb");
for(vari=0;i<obj.length;i++){
if(obj[i].checked){
getZlbNews(obj[i].value);
}
}
}
functiongetZlbNews(){
(通过Ajax获取map类型的数据;返回数据为result,json格式)
varjson=eval("("+result+")");//转化为json对象
//通过ID获取子类型要显示的区域
varparent=document.getElementById('xsqy');
//把子区域置空,防止下次追加
parent.innerHTML='';
varp=0;
varspan="";
//把全选打上勾
document.getElementById("selectall").checked=true;
for(variinjson){
p++;
span="<SPANstyle=\"display:inline-block;width:75px;\"><inputtype=\"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
*/
publicStringgetZLb(){
Map<Integer,String>zlb=service.getZLB();
//把map转化为json格式
JSONa=JSONSerializer.toJSON(zlb);
returna.toString();
}
5:js控制全选,及全选是否选中的逻辑,及提交时如何合并选中的代码
/**
*全选或是全部取消
*/
functionselectAllDz(){
varcheckboxs=document.getElementsByName("zlb");
for(vari=0;i<checkboxs.length;i++){
//根据全选的按钮是否选中来控制子类别是否选中
checkboxs[i].checked=document.getElementById("selectall").checked;
}
}
/**
*判断子类别是否全选,是全选则全选按钮选中,否则不选中
*/
functioncheckSelectAll(){
varcheckboxs=document.getElementsByName("zlb");
varisSelectAll=true;
for(vari=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,以逗号分隔
**/
functiongetAllIdStr(checkName){
varselect=document.getElementsByName(checkName);
varidStr=newArray();
for(vari=0;i<select.length;i++){
if(select[i].checked==true){
idStr=idStr.concat(select[i].value);
}
}
returnidStr.join(',');
}
6:在进行下一步操作时,如提交时,把全选的变成一个字符,赋值给一个隐藏的文本框,用来提交到后台
//调用拼接ID的方法,把要操作的元素名字传过去
varallZlb=getAllIdStr('zlb');
//创建一个隐藏的文本框,把拼接后的赋之,用于后台获取
document.getElementById('allZlbStr').value=allZlb;
以上只是个人拙见,如有更好的处理建议,请告知。
以上就是小编为大家带来的js动态获取子复选项并设计全选及提交的实现方法全部内容了,希望大家多多支持毛票票~