亚洲一级电影在线观看,九九精品无码专区免费,亚洲AV无码资源在线观看 ,欧美国产高清

ajax解決的下拉框的onchange問題

時間:2024-10-27 02:55:39 AJAX 我要投稿
  • 相關推薦

ajax解決的下拉框的onchange問題

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

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

  現在我具體談談這個ajax實現的過程。

  首先頁面當然需要定義一個下拉框的html控件。

  復制代碼 代碼如下:

  

  接下來當然是定義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是不是也有了

  更好的認識呢?

【ajax解決的下拉框的onchange問題】相關文章:

解決寶寶睡覺問題10-11

基于解決問題的學習10-13

Struts中文問題怎么解決09-09

如何解決頭皮問題08-22

解決電腦變慢問題的方法08-10

零基礎學習AJAX之制作自動校驗的表單問題07-25

如何解決狗狗掉毛的問題-有效解決狗狗掉毛問題的方法06-17

解決硬盤故障各種奇異問題02-21

集團OA系統解決哪些問題12-28

繡眉解決哪些眉毛問題09-10

主站蜘蛛池模板: 动漫av纯肉无码av在线播放| 亚洲精品tv久久久久久久久 | 黄色视频免费| 无码专区人妻系列日韩精品少妇 | 香蕉在线 亚洲 欧美 专区| 内射干少妇亚洲69xxx| 97视频在线精品国自产拍| 亚洲蜜桃v妇女| 中文字幕一区二区三区波多野结衣 | 久久96热在精品国产高清| 国产精品进线69影院| 亚洲综合最新无码2020av| 护士脱了内裤让我爽了一夜视频| 午夜福利精品导航凹凸| 亚洲首页国产精品丝袜| 少妇精品无码一区二区免费视频| 无遮挡十八禁污污网站在线观看| 熟妇久久网| 综合激情五月丁香久久| 亚洲精品毛片一区二区三区| 卓资县| 96国产xxxx免费视频| 亚洲精品国产嫩草在线观看东京热| 亚洲色成人一区二区三区小说| 天天色综合4| 强制高潮18xxxxhd日韩| 无码专区一va亚洲v专区在线| 阜城县| 囯产精品一品二区三区| 精品无码久久久久久尤物| 日本成人字幕在线不卡| 久久人人97超碰国产精品| 337p日本欧洲亚洲大胆裸体艺术 | 亚洲毛片不卡av在线播放一区| 欧美熟妇另类久久久久久不卡| 55夜色66夜色国产精品视频| 97久久久精品综合88久久| 亚洲中文超碰中文字幕| 88av在线播放| 国产成人年无码av片在线观看| 中文字幕一精品亚洲无线一区|