欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js動(dòng)態(tài)獲取子復(fù)選項(xiàng)并設(shè)計(jì)全選及提交的實(shí)現(xiàn)方法

 更新時(shí)間:2016年06月24日 09:02:54   投稿:jingxian  
下面小編就為大家?guī)?lái)一篇js動(dòng)態(tài)獲取子復(fù)選項(xiàng)并設(shè)計(jì)全選及提交的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的, 現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

在做項(xiàng)目的時(shí)候,會(huì)遇到根據(jù)父選項(xiàng),動(dòng)態(tài)的獲取子選項(xiàng),并列出多個(gè)復(fù)選框,提交時(shí),把選中的合并成一個(gè)字符提交后臺(tái)

本章將講述如何通過(guò)js控制實(shí)現(xiàn)該操作:

1:設(shè)計(jì)父類別為radio,為每一個(gè)radio都加上onclick事件,并默認(rèn)類別1為選擇狀態(tài)。

<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:頁(yè)面初加載時(shí),要根據(jù)選中的父類別顯示子類別,在點(diǎn)擊按鈕時(shí),也要獲取子類別,故寫成同一個(gè)方法,并在頁(yè)面加載結(jié)束后調(diào)用

window.onload=getZlb();

3:獲取子類別的js方法,通過(guò)ajax方法動(dòng)態(tài)獲取后臺(tái)數(shù)據(jù)

/**
 * 獲取子類別,在頁(yè)面加載結(jié)束后也執(zhí)行顯示
 */
 function getZlb(){
  //通過(guò)名字獲取
  var obj = document.getElementsByName("lb");
    for(var i=0; i<obj.length; i ++){
      if(obj[i].checked){
        getZlbNews(obj[i].value);
      }
  }
 }

function getZlbNews(){
    (通過(guò)Ajax獲取map類型的數(shù)據(jù);返回?cái)?shù)據(jù)為result,json格式)
    var json = eval("("+result+")"); //轉(zhuǎn)化為json對(duì)象
    //通過(guò)ID獲取子類型要顯示的區(qū)域
    var parent=document.getElementById('xsqy');
    //把子區(qū)域置空,防止下次追加
    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>";
     //當(dāng)子復(fù)選框超過(guò)11個(gè),則換行
     if(p%11==0){
       span=span+"<br>";
     }
     //把子復(fù)選框一個(gè)個(gè)追加到子區(qū)域
     parent.innerHTML=parent.innerHTML+span;
    } 
}

4:后臺(tái)邏輯,

/**
   * 通過(guò)子類別,返回Map格式 Map<代碼,名稱>
   * @return
   */
  public String getZLb(){
    Map<Integer, String> zlb=service.getZLB();
    //把map轉(zhuǎn)化為json格式
    JSON a= JSONSerializer.toJSON(zlb);
    return a.toString();
  }

5:js控制全選,及全選是否選中的邏輯,及提交時(shí)如何合并選中的代碼

/**
  * 全選或是全部取消
  */
 function selectAllDz(){
   var checkboxs = document.getElementsByName("zlb");
   for(var i=0; i<checkboxs.length; i++) {
      //根據(jù)全選的按鈕是否選中來(lá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,以逗號(hào)分隔
**/
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:在進(jìn)行下一步操作時(shí),如提交時(shí),把全選的變成一個(gè)字符,賦值給一個(gè)隱藏的文本框,用來(lái)提交到后臺(tái)

//調(diào)用拼接ID的方法,把要操作的元素名字傳過(guò)去
var allZlb=getAllIdStr('zlb');
//創(chuàng)建一個(gè)隱藏的文本框,把拼接后的賦之,用于后臺(tái)獲取
document.getElementById('allZlbStr').value=allZlb;

以上只是個(gè)人拙見,如有更好的處理建議,請(qǐng)告知。

以上就是小編為大家?guī)?lái)的js動(dòng)態(tài)獲取子復(fù)選項(xiàng)并設(shè)計(jì)全選及提交的實(shí)現(xiàn)方法全部?jī)?nèi)容了,希望大家多多支持腳本之家~

相關(guān)文章

  • 關(guān)于VSCode格式化JS自動(dòng)添加或去掉分號(hào)的問(wèn)題

    關(guān)于VSCode格式化JS自動(dòng)添加或去掉分號(hào)的問(wèn)題

    這篇文章主要介紹了VSCode格式化JS自動(dòng)添加或去掉分號(hào)的問(wèn)題,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-10-10
  • javascript實(shí)現(xiàn)緩動(dòng)動(dòng)畫效果

    javascript實(shí)現(xiàn)緩動(dòng)動(dòng)畫效果

    這篇文章主要為大家詳細(xì)介紹了javascript實(shí)現(xiàn)緩動(dòng)動(dòng)畫效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • JavaScript數(shù)組之展開運(yùn)算符詳解

    JavaScript數(shù)組之展開運(yùn)算符詳解

    這篇文章主要給大家介紹了關(guān)于JavaScript數(shù)組之展開運(yùn)算符的相關(guān)資料,你可以通過(guò)展開操作符(Spread operator)擴(kuò)展一個(gè)數(shù)組對(duì)象和字符串,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-12-12
  • JavaScript操作Oracle數(shù)據(jù)庫(kù)示例

    JavaScript操作Oracle數(shù)據(jù)庫(kù)示例

    這篇文章主要介紹了JavaScript操作Oracle數(shù)據(jù)庫(kù)示例,本文使用ActiveXObject實(shí)現(xiàn)訪問(wèn)Oracle數(shù)據(jù)庫(kù),需要的朋友可以參考下
    2015-03-03
  • BootStrap tooltip提示框使用小結(jié)

    BootStrap tooltip提示框使用小結(jié)

    這篇文章主要為大家詳細(xì)介紹了BootStrap tooltip提示框使用小結(jié) ,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • js使用cookie記錄用戶名的方法

    js使用cookie記錄用戶名的方法

    這篇文章主要介紹了js使用cookie記錄用戶名的方法,通過(guò)完整實(shí)例形式分析了JavaScript針對(duì)cookie的創(chuàng)建、賦值及刪除等操作技巧,以及通過(guò)cookie記錄用戶登錄信息的方法,需要的朋友可以參考下
    2015-11-11
  • JS小功能(button選擇顏色)簡(jiǎn)單實(shí)例

    JS小功能(button選擇顏色)簡(jiǎn)單實(shí)例

    這篇文章主要介紹了button選擇顏色簡(jiǎn)單實(shí)例,有需要的朋友可以參考一下
    2013-11-11
  • 如何基于filter實(shí)現(xiàn)網(wǎng)站整體變灰功能

    如何基于filter實(shí)現(xiàn)網(wǎng)站整體變灰功能

    這篇文章主要介紹了如何基于filter實(shí)現(xiàn)網(wǎng)站整體變灰功能,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-04-04
  • 原生js輪播特效

    原生js輪播特效

    這篇文章主要為大家詳細(xì)介紹了原生js輪播特效,簡(jiǎn)單實(shí)用的代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • JS中使用變量保存arguments對(duì)象的方法

    JS中使用變量保存arguments對(duì)象的方法

    這篇文章主要介紹了JS中使用變量保存arguments對(duì)象的方法的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06

最新評(píng)論