即在觸發地區下拉框的onchange事件時,代理商的下拉框選項也相應的改變,比如選擇地區 湖南—〉長沙,那麼代理商下拉框只顯示長沙的代理商。
本來認為這個很好實現,但實際改起來的時候發現問題多多,主要問題是原有的地區聯動是用js實現的,它的數據源是一個xml文件,當然如果下拉框是服務器端控件那麼問題是很好解決的,現在是html控件一下子似乎還真有些不好改,想了幾種辦法實現起來都不理想,最後將思路轉向用ajax來實現問題才迎刃而解,現在仔細一想,像這種情況似乎只有用ajax才能比較好的.解決,如果是在地區下拉框的onchange事件裏向後台進行一次提交,將地區下拉框的id傳過去的話,實際上產生的回發會將地區聯動下拉框重新初始化。
現在我具體談談這個ajax實現的過程。
首先頁面當然需要定義一個下拉框的html控件。
複製代碼 代碼如下:
接下來當然是定義XmlHttpRequest對象。
複製代碼 代碼如下:
var xmlhttp;
function CreateXmlHttp()
{
//非IE瀏覽器創建XmlHttpRequest對象
if(ttpRequest)
{
xmlhttp=new XmlHttpRequest();
}
//IE瀏覽器創建XmlHttpRequest對象
if(veXObject)
{
try
{
xmlhttp=new ActiveXObject("TTP");
}
catch(e)
{
try{
xmlhttp=new ActiveXObject("TTP");
}
catch(ex){}
}
}
}
這個在我的多篇blog文章裏都有闡述,就不多説了。
接下來當然是利用該對象來發送條件,獲得數據,並且將獲得的數據綁定到agent這個下拉框。
在地區下拉框的onchange事件裏面觸發函數AjaxSend();
複製代碼 代碼如下:
function AjaxSend()
{
//創建XmlHttpRequest對象
CreateXmlHttp();
if(!xmlhttp)
{
alert("創建xmlhttpRequest發生異常!");
return false;
}
//獲取地區下拉框的value值,作為條件發送
var ss=lementById("a2")tring(0,4);
}
//要發送的url,UserAjax我專門用來取數據
url="
("POST",url,false);
adystatechange=function()
{
if(yState==4)
{
if(us==200)
{
//清空原下拉框
lementById("agent")th=0;
//str為返回的一個字符串,形式為"0001/代理商1,0002/代理商2,0003/代理商3"
var str=onseText;
//將該字符串分割為數組形式
var strs=t(",");
lementById("agent")(new Option("----------","000000"));
for(var i=0;i<th-1;i++)
{
//獲取value值(編號)
var a=strs[i]tring(0,strs[i]IndexOf("/"));
//獲取綁定內容
var b=strs[i]tring(strs[i]IndexOf("/")+1,th);
//綁定到下拉框
lementById("agent")(new Option(b,a));
}
}
}
}
();
}
另外順便介紹一下UserAjax接收到該地區編號後獲取數據返回字符串的過程。
複製代碼 代碼如下:
string Area = yString["area"]ring();
DataTable data = "生成DataTable,涉及到公司核心代碼,省略"
string aa = "";
for (int i = 0; i < t; i++)
{
if (aa == "")
{
aa = [i]["id"]ring()+"/"+[i]["name"]ring();
}
else
{
aa = aa + "," + [i]["id"]ring() +"/"+ [i]["name"]ring();
}
}
e(aa);
這樣,一個比較棘手的問題用ajax就獲得了完美解決,並且不會因向後台回發而導致下拉框初始化,導致選項改變,親愛的朋友,看了這個例子,你對ajax是不是也有了
更好的認識呢?