在做项目的时候,会遇到根据父选项,动态的获取子选项,并列出多个复选框,提交时,把选中的合并成一个字符提交后台
本章将讲述如何通过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;
以上只是个人拙见,如有更好的处理建议,请告知。
以上就是小编为大家带来的js动态获取子复选项并设计全选及提交的实现方法全部内容了,希望大家多多支持~
华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年09月21日
2024年09月21日
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- 任天堂今晚举行直面会!第三方及独立游戏展示
- 《哆啦A梦的铜锣烧店物语》发售!开罗公式+哆啦A梦
- 任天堂公布《塞尔达传说》系列时间线:野炊与王泪独立在外
- 五条人.2012-一些风景2CD【刀马旦】【WAV+CUE】
- 陈奕迅.2013-Easons.Life演唱会2CD(2024环球红馆40复刻系列)【环球】【WAV+CUE】
- 许美静.1995-遗憾(新马版)【上华】【WAV+CUE】
- 《叶倩文 歌声情缘》[WAV+CUE][410MB]
- 《张国荣 首首动听经典不容错过 追忆的风 2CD》[WAV+CUE][870MB]
- 《腾格尔 容中尔甲 亚东 高原三星 男人篇 3CD》[WAV/分轨][1GB]
- 命运圣契公测实测可用兑换码大全 命运圣契最新兑换码分享
- 黑神话悟空上品疾蝠精魄获取方法一览|上品疾蝠精魄收集攻略
- 《七龙珠电光炸裂!ZERO》GT角色预告片曝光,15位新角色登场
- [ABC]安娜-胆麦发烧女声[6N纯银镀膜][2016[低速原抓WAV+CUE]
- NewViennaOctetViennaWindSoloists-TheDeccaRecordings(2024)18CD[24-48][FLAC]-7