js動態(tài)獲取子復選項并設(shè)計全選及提交的實現(xiàn)方法
在做項目的時候,會遇到根據(jù)父選項,動態(tài)的獲取子選項,并列出多個復選框,提交時,把選中的合并成一個字符提交后臺
本章將講述如何通過js控制實現(xiàn)該操作:
1:設(shè)計父類別為radio,為每一個radio都加上onclick事件,并默認類別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:頁面初加載時,要根據(jù)選中的父類別顯示子類別,在點擊按鈕時,也要獲取子類別,故寫成同一個方法,并在頁面加載結(jié)束后調(diào)用
window.onload=getZlb();
3:獲取子類別的js方法,通過ajax方法動態(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ù);返回數(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>"; //當子復選框超過11個,則換行 if(p%11==0){ span=span+"<br>"; } //把子復選框一個個追加到子區(qū)域 parent.innerHTML=parent.innerHTML+span; } }
4:后臺邏輯,
/** * 通過子類別,返回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控制全選,及全選是否選中的邏輯,及提交時如何合并選中的代碼
/** * 全選或是全部取消 */ 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,以逗號分隔 **/ 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:在進行下一步操作時,如提交時,把全選的變成一個字符,賦值給一個隱藏的文本框,用來提交到后臺
//調(diào)用拼接ID的方法,把要操作的元素名字傳過去 var allZlb=getAllIdStr('zlb'); //創(chuàng)建一個隱藏的文本框,把拼接后的賦之,用于后臺獲取 document.getElementById('allZlbStr').value=allZlb;
以上只是個人拙見,如有更好的處理建議,請告知。
以上就是小編為大家?guī)淼膉s動態(tài)獲取子復選項并設(shè)計全選及提交的實現(xiàn)方法全部內(nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
關(guān)于VSCode格式化JS自動添加或去掉分號的問題
這篇文章主要介紹了VSCode格式化JS自動添加或去掉分號的問題,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-10-10JavaScript操作Oracle數(shù)據(jù)庫示例
這篇文章主要介紹了JavaScript操作Oracle數(shù)據(jù)庫示例,本文使用ActiveXObject實現(xiàn)訪問Oracle數(shù)據(jù)庫,需要的朋友可以參考下2015-03-03如何基于filter實現(xiàn)網(wǎng)站整體變灰功能
這篇文章主要介紹了如何基于filter實現(xiàn)網(wǎng)站整體變灰功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-04-04