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

前端技术 2023/09/09 JavaScript

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

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

本文地址:https://www.stayed.cn/item/25708

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。