js动态获取子复选项并设计全选及提交的实现方法

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

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

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

rush:xhtml;"> Box" name="selectall" id="selectall" onClick="selectAll();" checked="checked"/>全选
dio" name="lb" id="lb" value="1" onclick="getZlb(1);" checked="checked"/>类别1 dio" name="lb" id="lb" value="2" onclick="getZlb(2);"/>类别2 dio" name="lb" id="lb" value="3" onclick="getZlb(3);"/>类别3

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

rush:js;"> window.onload=getZlb();

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

rush:js;"> /** * 获取子类别,在页面加载结束后也执行显示 */ function getZlb(){ //通过名字获取 var obj = document.getElementsByName("lb"); for(var i=0; ifunction 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]+"";
//当子复选框超过11个,则换行
if(p%11==0){
span=span+"
";
}
//把子复选框一个个追加到子区域
parent.innerHTML=parent.innerHTML+span;
}
}

4:后台逻辑,

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

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

rush:js;"> /** * 全选或是全部取消 */ function selectAllDz(){ var checkBoxs = document.getElementsByName("zlb"); for(var i=0; iBoxs.length; i++) {       //根据全选的按钮是否选中来控制子类别是否选中 checkBoxs[i].checked = document.getElementById("selectall").checked; } } /** * 判断子类别是否全选,是全选则全选按钮选中,否则不选中 */ function checkSelectAll(){ var checkBoxs = document.getElementsByName("zlb"); var isSelectAll=true; for(var i=0; iBoxs.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

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

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

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

以上就是小编为大家带来的js动态获取子复选项并设计全选及提交的实现方法全部内容了,希望大家多多支持编程之家~

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...