<select id="Agent" name="Agent"></select>
接下來當然是定義XMLHttpRequest對象。
var XMLhttp;
function CreateXMLHttp()
{
//非IE浏覽器創建XMLHttpRequest對象
if(window.XMLHttpRequest)
{
xmlhttp=new XMLHttpRequest();
}
//IE浏覽器創建XMLHttpRequest對象
if(window.ActiveXObject)
{
try
{
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
catch(e)
{
try{
xmlhttp=new ActiveXObject("msxml2.XMLHTTP");
}
catch(ex){}
}
}
}
這個在我的多篇blog文章裡都有闡述,就不多說了。
接下來當然是利用該對象來發送條件,獲得數據,並且將獲得的數據綁定到agent這個下拉框。
在地區下拉框的onchange事件裡面觸發函數AJaxSend();
function AJaxSend()
{
//創建XMLHttpRequest對象
CreateXMLHttp();
if(!XMLhttp)
{
alert("創建XMLhttpRequest發生異常!");
return false;
}
//獲取地區下拉框的value值,作為條件發送
var ss=document.getElementById("a2").value.substring(0,4);
}
//要發送的url,UserAJax我專門用來取數據
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為返回的一個字符串,形式為"0001/代理商1,0002/代理商2,0003/代理商3"
var str=XMLhttp.responseText;
//將該字符串分割為數組形式
var strs=str.split(",");
document.getElementById("agent").options.add(new Option("----------","000000"));
for(var i=0;i<strs.length-1;i++)
{
//獲取value值(編號)
var a=strs[i].substring(0,strs[i].lastIndexOf("/"));
//獲取綁定內容
var b=strs[i].substring(strs[i].lastIndexOf("/")+1,strs.length);
//綁定到下拉框
document.getElementById("agent").options.add(new Option(b,a));
}
}
}
}
XMLhttp.send();
}
另外順便介紹一下UserAJax接收到該地區編號後獲取數據返回字符串的過程。
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);