婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁 > 知識庫 > ajax完美解決的下拉框的onchange問題

ajax完美解決的下拉框的onchange問題

熱門標簽:廣西ai語音電銷機器人哪家好 察縣地圖標注 如何用地圖標注各分公司 接聽電話機器人哪有 蓄意標記地圖標注 莆田防封電銷卡價格 電銷機器人適用范圍 信貸電銷機器人有用嗎 辦理一個400電話多少錢
即在觸發地區下拉框的onchange事件時,代理商的下拉框選項也相應的改變,比如選擇地區 湖南—〉長沙,那么代理商下拉框只顯示長沙的代理商。

本來認為這個很好實現,但實際改起來的時候發現問題多多,主要問題是原有的地區聯動是用js實現的,它的數據源是一個xml文件,當然如果下拉框是服務器端控件那么問題是很好解決的,現在是html控件一下子似乎還真有些不好改,想了幾種辦法實現起來都不理想,最后將思路轉向用ajax來實現問題才迎刃而解,現在仔細一想,像這種情況似乎只有用ajax才能比較好的解決,如果是在地區下拉框的onchange事件里向后臺進行一次提交,將地區下拉框的id傳過去的話,實際上產生的回發會將地區聯動下拉框重新初始化。

現在我具體談談這個ajax實現的過程。
首先頁面當然需要定義一個下拉框的html控件。
復制代碼 代碼如下:

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;istrs.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);

這樣,一個比較棘手的問題用ajax就獲得了完美解決,并且不會因向后臺回發而導致下拉框初始化,導致選項改變,親愛的朋友,看了這個例子,你對ajax是不是也有了
更好的認識呢?
您可能感興趣的文章:
  • asp.net 實現下拉框只讀功能
  • js制作的鼠標懸浮時產生的下拉框效果
  • js+xml生成級聯下拉框代碼
  • Ajax實現無刷新三聯動下拉框
  • ajax 自動完成下拉框 自動提示位置問題
  • ajax struts2 下拉框賦值(適合所有)

標簽:張掖 阿拉善盟 鷹潭 平涼 益陽 延邊 銅陵 儋州

巨人網絡通訊聲明:本文標題《ajax完美解決的下拉框的onchange問題》,本文關鍵詞  ajax,完美,解決,的,下拉,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ajax完美解決的下拉框的onchange問題》相關的同類信息!
  • 本頁收集關于ajax完美解決的下拉框的onchange問題的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 山丹县| 彰化市| 庄河市| 莎车县| 抚州市| 社会| 留坝县| 闽侯县| 丰镇市| 铜陵市| 崇信县| 城固县| 黔江区| 五河县| 阿克| 穆棱市| 梁河县| 叶城县| 奎屯市| 莱西市| 嘉定区| 盐津县| 辽中县| 松桃| 东港市| 泰和县| 洪湖市| 乳山市| 永丰县| 南丰县| 龙胜| 西贡区| 县级市| 简阳市| 疏附县| 九台市| 什邡市| 贵州省| 镇原县| 咸阳市| 长子县|