ajax完美解決的下拉框的onchange問(wèn)題
更新時(shí)間:2010年08月05日 04:07:13 作者:
最近老總提了一個(gè)小功能,在搜索網(wǎng)吧列表的時(shí)候加上網(wǎng)吧所屬代理商這個(gè)條件,原有的搜索條件是一個(gè)地區(qū)二級(jí)聯(lián)動(dòng),現(xiàn)在需要根據(jù)不同的地區(qū)顯示不同的代理商集合。
即在觸發(fā)地區(qū)下拉框的onchange事件時(shí),代理商的下拉框選項(xiàng)也相應(yīng)的改變,比如選擇地區(qū) 湖南—〉長(zhǎng)沙,那么代理商下拉框只顯示長(zhǎng)沙的代理商。
本來(lái)認(rèn)為這個(gè)很好實(shí)現(xiàn),但實(shí)際改起來(lái)的時(shí)候發(fā)現(xiàn)問(wèn)題多多,主要問(wèn)題是原有的地區(qū)聯(lián)動(dòng)是用js實(shí)現(xiàn)的,它的數(shù)據(jù)源是一個(gè)xml文件,當(dāng)然如果下拉框是服務(wù)器端控件那么問(wèn)題是很好解決的,現(xiàn)在是html控件一下子似乎還真有些不好改,想了幾種辦法實(shí)現(xiàn)起來(lái)都不理想,最后將思路轉(zhuǎn)向用ajax來(lái)實(shí)現(xiàn)問(wèn)題才迎刃而解,現(xiàn)在仔細(xì)一想,像這種情況似乎只有用ajax才能比較好的解決,如果是在地區(qū)下拉框的onchange事件里向后臺(tái)進(jìn)行一次提交,將地區(qū)下拉框的id傳過(guò)去的話,實(shí)際上產(chǎn)生的回發(fā)會(huì)將地區(qū)聯(lián)動(dòng)下拉框重新初始化。
現(xiàn)在我具體談?wù)勥@個(gè)ajax實(shí)現(xiàn)的過(guò)程。
首先頁(yè)面當(dāng)然需要定義一個(gè)下拉框的html控件。
<select id="Agent" name="Agent"></select>
接下來(lái)當(dāng)然是定義XmlHttpRequest對(duì)象。
var xmlhttp;
function CreateXmlHttp()
{
//非IE瀏覽器創(chuàng)建XmlHttpRequest對(duì)象
if(window.XmlHttpRequest)
{
xmlhttp=new XmlHttpRequest();
}
//IE瀏覽器創(chuàng)建XmlHttpRequest對(duì)象
if(window.ActiveXObject)
{
try
{
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
catch(e)
{
try{
xmlhttp=new ActiveXObject("msxml2.XMLHTTP");
}
catch(ex){}
}
}
}
這個(gè)在我的多篇blog文章里都有闡述,就不多說(shuō)了。
接下來(lái)當(dāng)然是利用該對(duì)象來(lái)發(fā)送條件,獲得數(shù)據(jù),并且將獲得的數(shù)據(jù)綁定到agent這個(gè)下拉框。
在地區(qū)下拉框的onchange事件里面觸發(fā)函數(shù)AjaxSend();
function AjaxSend()
{
//創(chuàng)建XmlHttpRequest對(duì)象
CreateXmlHttp();
if(!xmlhttp)
{
alert("創(chuàng)建xmlhttpRequest發(fā)生異常!");
return false;
}
//獲取地區(qū)下拉框的value值,作為條件發(fā)送
var ss=document.getElementById("a2").value.substring(0,4);
}
//要發(fā)送的url,UserAjax我專門用來(lái)取數(shù)據(jù)
url="UserAjax.aspx?area="+ss;
xmlhttp.open("POST",url,false);
xmlhttp.onreadystatechange=function()
{
if(xmlhttp.readyState==4)
{
if(xmlhttp.status==200)
{
//清空原下拉框
document.getElementById("agent").options.length=0;
//str為返回的一個(gè)字符串,形式為"0001/代理商1,0002/代理商2,0003/代理商3"
var str=xmlhttp.responseText;
//將該字符串分割為數(shù)組形式
var strs=str.split(",");
document.getElementById("agent").options.add(new Option("----------","000000"));
for(var i=0;i<strs.length-1;i++)
{
//獲取value值(編號(hào))
var a=strs[i].substring(0,strs[i].lastIndexOf("/"));
//獲取綁定內(nèi)容
var b=strs[i].substring(strs[i].lastIndexOf("/")+1,strs.length);
//綁定到下拉框
document.getElementById("agent").options.add(new Option(b,a));
}
}
}
}
xmlhttp.send();
}
另外順便介紹一下UserAjax接收到該地區(qū)編號(hào)后獲取數(shù)據(jù)返回字符串的過(guò)程。
string Area = Request.QueryString["area"].ToString();
DataTable data = "生成DataTable,涉及到公司核心代碼,省略"
string aa = "";
for (int i = 0; i < data.Rows.Count; i++)
{
if (aa == "")
{
aa = data.Rows[i]["id"].ToString()+"/"+data.Rows[i]["name"].ToString();
}
else
{
aa = aa + "," + data.Rows[i]["id"].ToString() +"/"+ data.Rows[i]["name"].ToString();
}
}
Response.Write(aa);
這樣,一個(gè)比較棘手的問(wèn)題用ajax就獲得了完美解決,并且不會(huì)因向后臺(tái)回發(fā)而導(dǎo)致下拉框初始化,導(dǎo)致選項(xiàng)改變,親愛(ài)的朋友,看了這個(gè)例子,你對(duì)ajax是不是也有了
更好的認(rèn)識(shí)呢?
本來(lái)認(rèn)為這個(gè)很好實(shí)現(xiàn),但實(shí)際改起來(lái)的時(shí)候發(fā)現(xiàn)問(wèn)題多多,主要問(wèn)題是原有的地區(qū)聯(lián)動(dòng)是用js實(shí)現(xiàn)的,它的數(shù)據(jù)源是一個(gè)xml文件,當(dāng)然如果下拉框是服務(wù)器端控件那么問(wèn)題是很好解決的,現(xiàn)在是html控件一下子似乎還真有些不好改,想了幾種辦法實(shí)現(xiàn)起來(lái)都不理想,最后將思路轉(zhuǎn)向用ajax來(lái)實(shí)現(xiàn)問(wèn)題才迎刃而解,現(xiàn)在仔細(xì)一想,像這種情況似乎只有用ajax才能比較好的解決,如果是在地區(qū)下拉框的onchange事件里向后臺(tái)進(jìn)行一次提交,將地區(qū)下拉框的id傳過(guò)去的話,實(shí)際上產(chǎn)生的回發(fā)會(huì)將地區(qū)聯(lián)動(dòng)下拉框重新初始化。
現(xiàn)在我具體談?wù)勥@個(gè)ajax實(shí)現(xiàn)的過(guò)程。
首先頁(yè)面當(dāng)然需要定義一個(gè)下拉框的html控件。
復(fù)制代碼 代碼如下:
<select id="Agent" name="Agent"></select>
接下來(lái)當(dāng)然是定義XmlHttpRequest對(duì)象。
復(fù)制代碼 代碼如下:
var xmlhttp;
function CreateXmlHttp()
{
//非IE瀏覽器創(chuàng)建XmlHttpRequest對(duì)象
if(window.XmlHttpRequest)
{
xmlhttp=new XmlHttpRequest();
}
//IE瀏覽器創(chuàng)建XmlHttpRequest對(duì)象
if(window.ActiveXObject)
{
try
{
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
catch(e)
{
try{
xmlhttp=new ActiveXObject("msxml2.XMLHTTP");
}
catch(ex){}
}
}
}
這個(gè)在我的多篇blog文章里都有闡述,就不多說(shuō)了。
接下來(lái)當(dāng)然是利用該對(duì)象來(lái)發(fā)送條件,獲得數(shù)據(jù),并且將獲得的數(shù)據(jù)綁定到agent這個(gè)下拉框。
在地區(qū)下拉框的onchange事件里面觸發(fā)函數(shù)AjaxSend();
復(fù)制代碼 代碼如下:
function AjaxSend()
{
//創(chuàng)建XmlHttpRequest對(duì)象
CreateXmlHttp();
if(!xmlhttp)
{
alert("創(chuàng)建xmlhttpRequest發(fā)生異常!");
return false;
}
//獲取地區(qū)下拉框的value值,作為條件發(fā)送
var ss=document.getElementById("a2").value.substring(0,4);
}
//要發(fā)送的url,UserAjax我專門用來(lái)取數(shù)據(jù)
url="UserAjax.aspx?area="+ss;
xmlhttp.open("POST",url,false);
xmlhttp.onreadystatechange=function()
{
if(xmlhttp.readyState==4)
{
if(xmlhttp.status==200)
{
//清空原下拉框
document.getElementById("agent").options.length=0;
//str為返回的一個(gè)字符串,形式為"0001/代理商1,0002/代理商2,0003/代理商3"
var str=xmlhttp.responseText;
//將該字符串分割為數(shù)組形式
var strs=str.split(",");
document.getElementById("agent").options.add(new Option("----------","000000"));
for(var i=0;i<strs.length-1;i++)
{
//獲取value值(編號(hào))
var a=strs[i].substring(0,strs[i].lastIndexOf("/"));
//獲取綁定內(nèi)容
var b=strs[i].substring(strs[i].lastIndexOf("/")+1,strs.length);
//綁定到下拉框
document.getElementById("agent").options.add(new Option(b,a));
}
}
}
}
xmlhttp.send();
}
另外順便介紹一下UserAjax接收到該地區(qū)編號(hào)后獲取數(shù)據(jù)返回字符串的過(guò)程。
復(fù)制代碼 代碼如下:
string Area = Request.QueryString["area"].ToString();
DataTable data = "生成DataTable,涉及到公司核心代碼,省略"
string aa = "";
for (int i = 0; i < data.Rows.Count; i++)
{
if (aa == "")
{
aa = data.Rows[i]["id"].ToString()+"/"+data.Rows[i]["name"].ToString();
}
else
{
aa = aa + "," + data.Rows[i]["id"].ToString() +"/"+ data.Rows[i]["name"].ToString();
}
}
Response.Write(aa);
這樣,一個(gè)比較棘手的問(wèn)題用ajax就獲得了完美解決,并且不會(huì)因向后臺(tái)回發(fā)而導(dǎo)致下拉框初始化,導(dǎo)致選項(xiàng)改變,親愛(ài)的朋友,看了這個(gè)例子,你對(duì)ajax是不是也有了
更好的認(rèn)識(shí)呢?
相關(guān)文章
Ajax 上傳圖片并預(yù)覽的簡(jiǎn)單實(shí)現(xiàn)
下面小編就為大家?guī)?lái)一篇Ajax 上傳圖片并預(yù)覽的簡(jiǎn)單實(shí)現(xiàn)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-09-09活到老學(xué)到老學(xué)習(xí)AJAX跨域(三)
學(xué)習(xí)AJAX其實(shí)有個(gè)很重要的應(yīng)用,就是為了執(zhí)行另外幾個(gè)站點(diǎn)的ASP,返回結(jié)果。通過(guò)本文給大家介紹ajax跨域相關(guān)知識(shí),需要的朋友參考下2016-02-02使用Nginx 反向代理來(lái)避免 ajax 跨域請(qǐng)求的方法
這篇文章主要介紹了使用Nginx 反向代理來(lái)避免 ajax 跨域請(qǐng)求的方法的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,需要的朋友可以參考下2016-06-06ajaxrequest.js ajaxrequest 0.7最新版 使用AJAXRequest進(jìn)行AJAX應(yīng)用程序開(kāi)發(fā)入
ajaxrequest.js ajaxrequest 0.7最新版 使用AJAXRequest進(jìn)行AJAX應(yīng)用程序開(kāi)發(fā)入門小技巧...2007-12-12Ajax動(dòng)態(tài)加載數(shù)據(jù)庫(kù)示例
這篇文章主要介紹的是一個(gè)Ajax動(dòng)態(tài)加載數(shù)據(jù)庫(kù)示例,需要的朋友可以參考下2014-05-05IE8用ajax訪問(wèn)不能每次都刷新的問(wèn)題
這篇文章主要介紹了IE8用ajax訪問(wèn)不能每次都刷新的問(wèn)題 的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07用ajax實(shí)現(xiàn)在單擊事件下加載一個(gè)DIV層的腳本
用ajax實(shí)現(xiàn)在單擊事件下加載一個(gè)DIV層的腳本...2007-11-11