基于Ajax實(shí)現(xiàn)下拉框聯(lián)動(dòng)顯示數(shù)據(jù)
公司做項(xiàng)目的時(shí)候,需要用到下拉框聯(lián)動(dòng)顯示數(shù)據(jù)的功能,索性利用Ajax來(lái)實(shí)現(xiàn),看到時(shí)間比較充裕,就沒(méi)去找demo自己去想方法寫(xiě)了。純自己的想法,有些可能比較弱智,希望不要見(jiàn)笑。
頁(yè)面中的兩個(gè)下拉列表框:
<tr> <td style="width: 130px"> 所在學(xué)院:</td> <td style="width: 100px"> <select id="college" style="width: 200px" runat="server" onchange="changcollege(this.value)"> <option value="0"> --請(qǐng)選擇所在學(xué)院學(xué)院-- </option> </select></td> </tr> <tr> <td style="width: 130px"> 所在專(zhuān)業(yè):</td> <td style="width: 100px"> <select id="specialty" style="width: 200px" runat="server" onchange="SaveSpecical(this.value)"> <option value="0"> --請(qǐng)選擇所在專(zhuān)業(yè)-- </option> </select></td> </tr>
JS腳本代碼:
<script type="text/javascript"> var http_request = false; function send_request(method,url,content,responseType,callback)//定義發(fā)送請(qǐng)求的函數(shù) { http_request=false; if(window.XMLHttpRequest) { http_request=new XMLHttpRequest(); if(http_request.overrideMimeType) { http_request.overrideMimeType("text/xml"); } } else { try { http_request=new ActiveXObject("Msxml2.XMLHTTP"); } catch(e) { try { http_request=new ActiveXObject("Microsoft.XMLHTTP"); } catch(e) {} } } if(!http_request) { window.alert("創(chuàng)建XMLHttpRequest對(duì)象失敗"); return false; } if(responseType.toLowerCase()=="text") { http_request.onreadystatechange=callback; } else { window.alert("ERR"); return false; } if(method.toLowerCase()=="get") { http_request.open(method,url,true); } else if(method.toLowerCase()=="post") { http_request.open(method,url,true); http_request.setRequestHeader("Content-Type","application/x-www-form-urlencoded"); } else { window.alert("Err"); return false; } http_request.send(content); } function changcollege(va)//當(dāng)學(xué)院下拉列表發(fā)生改變時(shí)觸發(fā)的腳本事件 { if(va!='0') { var speciality = document.getElementById("specialty"); speciality.disabled=false; var url="Handler.ashx?type=college&id="+va; send_request("GET",url,null,"text",populateClass3); } } function populateClass3()//Ajax執(zhí)行成功的回調(diào)函數(shù) { var f=document.getElementById("specialty"); if(http_request.readyState==4) { if(http_request.status==200) { var list=http_request.responseText; var classList=list.split("|"); f.options.length=1; for(var i=0;i<classList.length;i++) //將取得的結(jié)果添加到下級(jí)的列表框中 { var tmp=classList[i].split(","); f.add(new Option(tmp[1],tmp[0])); } } else { alert("您所請(qǐng)求的頁(yè)面有異常。"); } } } </script>
我們將http請(qǐng)求發(fā)送給服務(wù)端的Handler.ashx進(jìn)行處理。
public class Handler : IHttpHandler { public void ProcessRequest(HttpContext context) { string type = context.Request.QueryString["type"]; if (type.Equals("college")) { string id = context.Request.QueryString["id"]; context.Response.ContentType = "text/plain"; context.Response.Write(getSpecialty(id));//這個(gè)是從數(shù)據(jù)庫(kù)中根據(jù)傳來(lái)省的id 查詢出來(lái)的。學(xué)院的名字和主鍵,主鍵以便去查專(zhuān)業(yè)的名字 } } public string getSpecialty(string college) { DataSet ds = GetInformation.GetSpecialtyInfo(college); string str = ""; for (int i = 0; i < ds.Tables[0].Rows.Count; i++) { if (i == ds.Tables[0].Rows.Count - 1) { str += ds.Tables[0].Rows[i]["SpecialtyID"].ToString() + "," + ds.Tables[0].Rows[i]["SpecialtyName"].ToString(); } else { str += ds.Tables[0].Rows[i]["SpecialtyID"].ToString() + "," + ds.Tables[0].Rows[i]["SpecialtyName"].ToString() + "|"; } } return str.Trim(); } public bool IsReusable { get { return false; } } }
根據(jù)學(xué)院的編號(hào)獲得相應(yīng)的專(zhuān)業(yè),并將專(zhuān)業(yè)的名稱(chēng)用“|”分割組合成字符串返回給客戶端,客戶端腳本拆分字符串添加到下拉框中。
這里只是二級(jí)的聯(lián)動(dòng)顯示,三級(jí)聯(lián)動(dòng)數(shù)據(jù)的現(xiàn)實(shí)原理是一樣的。
本文的全部?jī)?nèi)容就到此結(jié)束了,希望大家學(xué)習(xí)Ajax實(shí)現(xiàn)下拉框聯(lián)動(dòng)顯示數(shù)據(jù)有所幫助。
- ajax三級(jí)聯(lián)動(dòng)下拉菜單效果
- AJAX省市區(qū)三級(jí)聯(lián)動(dòng)下拉菜單(java版)
- ThinkPHP使用心得分享-ThinkPHP + Ajax 實(shí)現(xiàn)2級(jí)聯(lián)動(dòng)下拉菜單
- JavaScript Ajax Json實(shí)現(xiàn)上下級(jí)下拉框聯(lián)動(dòng)效果實(shí)例代碼
- AJAX解析XML實(shí)例之下拉框省、市二級(jí)聯(lián)動(dòng)
- jquery ajax實(shí)現(xiàn)下拉框三級(jí)無(wú)刷新聯(lián)動(dòng),且保存保持選中值狀態(tài)
- ajax讀取數(shù)據(jù)庫(kù)內(nèi)容實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)下拉選擇菜單示例
- Ajax實(shí)現(xiàn)無(wú)刷新三聯(lián)動(dòng)下拉框
- Jquery+ajax+JAVA(servlet)實(shí)現(xiàn)下拉菜單異步取值
- Ajax+Servlet實(shí)現(xiàn)無(wú)刷新下拉聯(lián)動(dòng)效果
相關(guān)文章
ASP+AJAX+ACCESS數(shù)據(jù)庫(kù)實(shí)例講解三個(gè)步驟分享
其實(shí)說(shuō)起AJAX的初級(jí)應(yīng)用是非常簡(jiǎn)單的,通俗的說(shuō)就是客戶端(javascript)與服務(wù)端(asp或php等)腳本語(yǔ)言的數(shù)據(jù)交互2012-07-07ajax簡(jiǎn)介_(kāi)動(dòng)力節(jié)點(diǎn)Java學(xué)院整理
這篇文章主要為大家詳細(xì)介紹了ajax基礎(chǔ)知識(shí)點(diǎn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06用 ajax 的方法解決網(wǎng)頁(yè)廣告顯示的問(wèn)題
用 ajax 的方法解決網(wǎng)頁(yè)廣告顯示的問(wèn)題...2006-12-12ajax實(shí)現(xiàn)的提交文章前進(jìn)行敏感詞審核的代碼
在做“文章敏感詞匯審核”功能的時(shí)候,開(kāi)始在把“審核”放在插入數(shù)據(jù)庫(kù)的時(shí)候,后來(lái)想有一個(gè)功能,能在用戶點(diǎn)擊“提交”按鈕的時(shí)候,給一個(gè)提示。這樣相對(duì)“友好”那么點(diǎn)。2010-02-02Ajax與mysql數(shù)據(jù)交互實(shí)現(xiàn)留言板功能
最近自己做了一個(gè)小demo,實(shí)現(xiàn)了Ajax與MySQL的數(shù)據(jù)交互,js部分用的是jq,后臺(tái)用的是PHP,數(shù)據(jù)庫(kù)是mysql,下面通過(guò)本文給大家詳細(xì)介紹下2016-12-12Ajax實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)菜單
這篇文章主要為大家詳細(xì)介紹了Ajax實(shí)現(xiàn)二級(jí)聯(lián)動(dòng)菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-11-11