js動(dòng)態(tài)獲取子復(fù)選項(xiàng)并設(shè)計(jì)全選及提交的實(shí)現(xiàn)方法
在做項(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對(duì)象
//通過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è)人拙見,如有更好的處理建議,請(qǐng)告知。
以上就是小編為大家?guī)淼膉s動(dòng)態(tài)獲取子復(fù)選項(xiàng)并設(shè)計(jì)全選及提交的實(shí)現(xiàn)方法全部?jī)?nèi)容了,希望大家多多支持腳本之家~
相關(guān)文章
JS碰撞運(yùn)動(dòng)實(shí)現(xiàn)方法詳解
這篇文章主要介紹了JS碰撞運(yùn)動(dòng)實(shí)現(xiàn)方法,詳細(xì)分析了碰撞運(yùn)動(dòng)的原理及相應(yīng)的javascript實(shí)現(xiàn)技巧,需要的朋友可以參考下2016-12-12
javascript 三組文字間隙滾動(dòng)實(shí)例代碼
非常實(shí)用的文字間隙滾動(dòng)效果代碼2008-06-06
JS判斷客服QQ號(hào)在線還是離線狀態(tài)的方法
這篇文章主要介紹了JS判斷客服QQ號(hào)在線還是離線狀態(tài)的方法,可實(shí)現(xiàn)完整的判斷QQ在線及對(duì)話的功能,是非常實(shí)用的技巧,需要的朋友可以參考下2015-01-01
JavaScript使用AOP編程思想實(shí)現(xiàn)監(jiān)聽HTTP請(qǐng)求
這篇文章主要為大家詳細(xì)介紹了如何在JavaScript使用AOP編程思想實(shí)現(xiàn)監(jiān)聽HTTP請(qǐng)求,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-02-02
TypeScript為對(duì)象動(dòng)態(tài)添加屬性代碼示例
這篇文章主要給大家介紹了關(guān)于TypeScript為對(duì)象動(dòng)態(tài)添加屬性的相關(guān)資料,在TypeScript 中,我們經(jīng)常需要在運(yùn)行時(shí)動(dòng)態(tài)添加屬性到對(duì)象上,需要的朋友可以參考下2023-07-07
uniapp返回上一頁并實(shí)現(xiàn)刷新界面數(shù)據(jù)的完整代碼
從一個(gè)列表界面點(diǎn)擊新增按鈕,進(jìn)入新增元素的界面,然后新增之后返回列表界面,并刷新列表界面,下面小編給大家分享uniapp返回上一頁,并實(shí)現(xiàn)刷新界面數(shù)據(jù)的代碼,感興趣的朋友跟隨小編一起看看吧2024-04-04
Bootstrap實(shí)現(xiàn)的表格合并單元格示例
這篇文章主要介紹了Bootstrap實(shí)現(xiàn)的表格合并單元格,涉及bootstrap界面布局相關(guān)操作技巧,需要的朋友可以參考下2018-02-02

