亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 開發 > AJAX > 正文

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

2024-09-01 08:31:27
字體:
來源:轉載
供稿:網友
最近老總提了一個小功能,在搜索網吧列表的時候加上網吧所屬代理商這個條件,原有的搜索條件是一個地區二級聯動,現在需要根據不同的地區顯示不同的代理商集合。

即在觸發地區下拉框的onchange事件時,代理商的下拉框選項也相應的改變,比如選擇地區 湖南—〉長沙,那么代理商下拉框只顯示長沙的代理商。

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

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

復制代碼 代碼如下:


<select></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);


這樣,一個比較棘手的問題用ajax就獲得了完美解決,并且不會因向后臺回發而導致下拉框初始化,導致選項改變,親愛的朋友,看了這個例子,你對ajax是不是也有了
更好的認識呢?
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产福利视频一区| 中文字幕日韩电影| 精品国产一区二区三区久久狼5月| 亚洲精品www| 国产一区欧美二区三区| 欧美另类精品xxxx孕妇| 国产精品第七十二页| 国产日韩综合一区二区性色av| 国产精品欧美亚洲777777| 精品亚洲aⅴ在线观看| 亚洲国产成人久久| 中文在线资源观看视频网站免费不卡| 91在线精品视频| 欧美性视频在线| 日韩精品福利在线| 亚洲国产日韩欧美在线图片| 国产99视频精品免视看7| 欧美亚洲第一页| 国产69精品久久久久99| 亚洲激情成人网| 日韩高清欧美高清| 成人激情视频在线播放| 亚洲国产私拍精品国模在线观看| 欧美性xxxxxxx| 蜜臀久久99精品久久久无需会员| 欧美激情第三页| 久久最新资源网| 日韩激情片免费| 国产精品wwww| 日韩三级影视基地| 久久精品青青大伊人av| 色偷偷av一区二区三区乱| 亚洲区中文字幕| 97人洗澡人人免费公开视频碰碰碰| 国模私拍视频一区| 九九热在线精品视频| 麻豆一区二区在线观看| 国产亚洲精品综合一区91| 日韩乱码在线视频| 日韩av色综合| 国产精品18久久久久久首页狼| 精品中文字幕乱| 国产在线不卡精品| 欧美日韩国产在线看| 日本亚洲欧美三级| 久久久久久亚洲精品不卡| 日韩美女在线看| 国产精品美女午夜av| 亚洲欧洲日产国码av系列天堂| 亚洲国模精品私拍| 日韩一区二区三区国产| 亚洲精品一区av在线播放| 国产精品久久久久999| 日日摸夜夜添一区| 欧美疯狂xxxx大交乱88av| 国产精品视频网站| 91干在线观看| 久热精品在线视频| 九九精品在线视频| 国产91精品网站| 精品一区二区亚洲| 日韩国产激情在线| 亚洲精品视频网上网址在线观看| 国产mv免费观看入口亚洲| 亚州欧美日韩中文视频| 国产精品丝袜久久久久久不卡| 国产精品成人观看视频国产奇米| 久久久国产在线视频| 久久影院免费观看| 中文字幕日韩欧美在线视频| 午夜精品99久久免费| 色综合天天综合网国产成人网| 好吊成人免视频| 亚洲国产欧美精品| 久久久黄色av| 亚洲国产成人精品久久久国产成人一区| 国产亚洲激情视频在线| 亚洲大胆美女视频| 精品久久久久久久久久久久久| 国产成+人+综合+亚洲欧美丁香花| 91久久久久久久久久久久久| 久久久视频精品| 亚洲精品国产美女| 日韩视频在线免费观看| 欧美wwwxxxx| 色哟哟网站入口亚洲精品| 国产亚洲视频中文字幕视频| 亚洲区免费影片| 国产成人免费av电影| 亚洲人成网站色ww在线| 色妞在线综合亚洲欧美| 国产免费一区二区三区在线能观看| 日韩av在线一区二区| 亚洲伦理中文字幕| 成人国产精品久久久| 国产亚洲欧美一区| 欧美另类第一页| 97成人精品视频在线观看| 亚洲欧美在线第一页| 久久777国产线看观看精品| 成人动漫网站在线观看| 欧美日韩国产在线| 亚洲精品免费网站| 亚洲国产精品成人一区二区| 亚洲精品视频网上网址在线观看| 亚洲精品欧美日韩| 国产精品久久久久久久app| 国产成人精品综合久久久| 97视频在线观看成人| 精品久久久久久亚洲精品| 欧美午夜性色大片在线观看| 国产亚洲激情视频在线| 久久人人爽人人爽人人片av高请| 91精品在线影院| 亚洲香蕉在线观看| 国产一区二区三区视频| 欧美有码在线视频| 欧美日韩免费区域视频在线观看| 亚洲美女精品久久| 国产精品福利在线观看| 中文字幕免费精品一区高清| 亚洲经典中文字幕| 久久免费精品日本久久中文字幕| 成人精品在线观看| 亚洲精品久久久久| 久久久久久伊人| 欧美在线影院在线视频| 日韩高清中文字幕| 欧美日韩一区二区精品| 国产精品日韩欧美| 欧美一区亚洲一区| 亚洲欧美另类在线观看| 大胆欧美人体视频| 久久久成人精品| 在线精品91av| 欧美黑人国产人伦爽爽爽| xx视频.9999.com| 久久久中精品2020中文| 亚洲日本成人女熟在线观看| 国产精品免费视频久久久| 日韩av影院在线观看| 成人精品福利视频| 欧美国产日韩视频| 久久久精品影院| 成人黄色片网站| 国产精品旅馆在线| 精品久久久国产| 欧美日韩国产999| 成人h视频在线| 久久久久久91香蕉国产| 国产91精品高潮白浆喷水| 中文字幕无线精品亚洲乱码一区| 亚洲精品免费一区二区三区| 欧美与欧洲交xxxx免费观看| 欧美日韩国产麻豆| 美乳少妇欧美精品| 97色在线播放视频| 日本a级片电影一区二区| 欧美激情精品久久久久久黑人| 伊人伊成久久人综合网小说| 日韩视频免费在线| 日韩在线免费高清视频| 国产精品综合不卡av| 国产综合色香蕉精品|