国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 09:36:46
字體:
供稿:網(wǎng)友

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

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

window.onload=getZlb();

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

/** * 獲取子類別,在頁面加載結(jié)束后也執(zhí)行顯示 */ 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類型的數(shù)據(jù);返回?cái)?shù)據(jù)為result,json格式)    var json = eval("("+result+")"); //轉(zhuǎn)化為json對象    //通過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ù)選框超過11個(gè),則換行     if(p%11==0){       span=span+"<br>";     }     //把子復(fù)選框一個(gè)個(gè)追加到子區(qū)域     parent.innerHTML=parent.innerHTML+span;    } }

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

/**   * 通過子類別,返回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ù)全選的按鈕是否選中來控制子類別是否選中     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è)隱藏的文本框,用來提交到后臺(tái)

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

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

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 黑龙江省| 朝阳区| 莆田市| 康定县| 治多县| 黔东| 陆丰市| 广河县| 邵阳县| 昆明市| 和龙市| 澄城县| 于田县| 保山市| 神木县| 肃宁县| 德江县| 江北区| 全州县| 南康市| 滦南县| 渝中区| 郓城县| 宝坻区| 卓尼县| 科技| 沿河| 寻甸| 花莲县| 平乐县| 濮阳县| 武胜县| 县级市| 宜章县| 筠连县| 伊通| 鲁山县| 乳源| 保定市| 抚顺县| 河池市|