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


Posted in Javascript onJune 24, 2016

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

本章将讲述如何通过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动态获取子复选项并设计全选及提交的实现方法全部内容了,希望大家多多支持三水点靠木~

Javascript 相关文章推荐
单独使用CKFinder选择图片的方法
Aug 21 Javascript
jQuery使用一个按钮控制图片的伸缩实现思路
Apr 19 Javascript
Jquery 分页插件之Jquery Pagination
Aug 25 Javascript
用JavaScript获取页面文档内容的实现代码
Jun 10 Javascript
深入理解Angularjs中的$resource服务
Dec 31 Javascript
Javascript ES6中数据类型Symbol的使用详解
May 02 Javascript
深入掌握 react的 setState的工作机制
Sep 27 Javascript
3种vue组件的书写形式
Nov 29 Javascript
一步步教你利用webpack如何搭一个vue脚手架(超详细讲解和注释)
Jan 08 Javascript
vue2.0 axios跨域并渲染的问题解决方法
Mar 08 Javascript
让webpack+vue-cil项目不再自动打开浏览器的方法
Sep 27 Javascript
原生javascript制作的拼图游戏实现方法详解
Feb 23 Javascript
EasyUI在表单提交之前进行验证的实例代码
Jun 24 #Javascript
正则表达式(语法篇推荐)
Jun 24 #Javascript
javascript弹出窗口中增加确定取消按钮
Jun 24 #Javascript
javascript类型系统_正则表达式RegExp类型详解
Jun 24 #Javascript
JQuery DIV 动态隐藏和显示的方法
Jun 23 #Javascript
微信QQ的二维码登录原理js代码解析
Jun 23 #Javascript
再次谈论Javascript中的this
Jun 23 #Javascript
You might like
社区(php&amp;&amp;mysql)五
2006/10/09 PHP
常见的PHP五种设计模式小结
2011/03/23 PHP
php处理多图上传压缩代码功能
2018/06/13 PHP
PHP-FPM 的管理和配置详解
2019/02/17 PHP
How to Auto Include a Javascript File
2007/02/02 Javascript
比较详细的关于javascript中void(0)的具体含义解释
2007/08/02 Javascript
Jquery 数组操作大全个人总结
2013/11/13 Javascript
将字符串中由空格隔开的每个单词首字母大写
2014/04/06 Javascript
jQuery实现简单网页遮罩层/弹出层效果兼容IE6、IE7
2014/06/16 Javascript
JavaScript利用append添加元素报错的解决方法
2014/07/01 Javascript
轻量级的原生js日历插件calendar.js使用指南
2015/04/28 Javascript
javascript作用域、作用域链(菜鸟必看)
2016/06/16 Javascript
使用Angular.js开发的注意事项
2016/10/19 Javascript
原生JavaScript实现Tooltip浮动提示框特效
2017/03/07 Javascript
如何使用less实现随机下雪动画详解
2019/01/02 Javascript
ES6知识点整理之模块化的应用详解
2019/04/15 Javascript
如何在vue中使用百度地图添加自定义覆盖物(水波纹)
2020/11/03 Javascript
python调用新浪微博API项目实践
2014/07/28 Python
Python运维开发之psutil库的使用详解
2018/10/18 Python
Python3中在Anaconda环境下安装basemap包
2018/10/21 Python
Python中如何使用if语句处理列表实例代码
2019/02/24 Python
python实现桌面托盘气泡提示
2019/07/29 Python
PyQt5高级界面控件之QTableWidget的具体使用方法
2020/02/23 Python
python中resample函数实现重采样和降采样代码
2020/02/25 Python
Python基于stuck实现scoket文件传输
2020/04/02 Python
如何使用localstorage代替cookie实现跨域共享数据问题
2018/04/18 HTML / CSS
Halston Heritage官网:简洁的日装,稍显奢华的晚装
2018/11/20 全球购物
德国最大的婴儿用品网上商店:Kidsroom.de(支持中文)
2020/09/02 全球购物
有兼职工作经历的简历自我评价
2014/03/07 职场文书
公司廉洁自律承诺书
2014/03/27 职场文书
公司领导班子召开党的群众路线教育实践活动总结大会新闻稿
2014/10/21 职场文书
三峡导游词
2015/01/31 职场文书
校长师德表现自我评价
2015/03/04 职场文书
刑事附带民事诉讼答辩状
2015/05/22 职场文书
python微信智能AI机器人实现多种支付方式
2022/04/12 Python
Nginx配置之禁止指定IP访问
2022/05/02 Servers