亚洲精品中文字幕无乱码_久久亚洲精品无码AV大片_最新国产免费Av网址_国产精品3级片

AJAX

ajax解決的下拉框的onchange問題

時間:2024-10-24 04:23:17 AJAX 我要投稿
  • 相關(guān)推薦

ajax解決的下拉框的onchange問題

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

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

  現(xiàn)在我具體談?wù)勥@個ajax實現(xiàn)的過程。

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

  復(fù)制代碼 代碼如下:

  

  接下來當(dāng)然是定義XmlHttpRequest對象。

  復(fù)制代碼 代碼如下:

  var xmlhttp;

  function CreateXmlHttp()

  {

  //非IE瀏覽器創(chuàng)建XmlHttpRequest對象

  if(window.XmlHttpRequest)

  {

  xmlhttp=new XmlHttpRequest();

  }

  //IE瀏覽器創(chuàng)建XmlHttpRequest對象

  if(window.ActiveXObject)

  {

  try

  {

  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");

  }

  catch(e)

  {

  try{

  xmlhttp=new ActiveXObject("msxml2.XMLHTTP");

  }

  catch(ex){}

  }

  }

  }

  這個在我的多篇blog文章里都有闡述,就不多說了。

  接下來當(dāng)然是利用該對象來發(fā)送條件,獲得數(shù)據(jù),并且將獲得的數(shù)據(jù)綁定到agent這個下拉框。

  在地區(qū)下拉框的onchange事件里面觸發(fā)函數(shù)AjaxSend();

  復(fù)制代碼 代碼如下:

  function AjaxSend()

  {

  //創(chuàng)建XmlHttpRequest對象

  CreateXmlHttp();

  if(!xmlhttp)

  {

  alert("創(chuàng)建xmlhttpRequest發(fā)生異常!");

  return false;

  }

  //獲取地區(qū)下拉框的value值,作為條件發(fā)送

  var ss=document.getElementById("a2").value.substring(0,4);

  }

  //要發(fā)送的url,UserAjax我專門用來取數(shù)據(jù)

  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;

  //將該字符串分割為數(shù)組形式

  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("/"));

  //獲取綁定內(nèi)容

  var b=strs[i].substring(strs[i].lastIndexOf("/")+1,strs.length);

  //綁定到下拉框

  document.getElementById("agent").options.add(new Option(b,a));

  }

  }

  }

  }

  xmlhttp.send();

  }

  另外順便介紹一下UserAjax接收到該地區(qū)編號后獲取數(shù)據(jù)返回字符串的過程。

  復(fù)制代碼 代碼如下:

  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就獲得了完美解決,并且不會因向后臺回發(fā)而導(dǎo)致下拉框初始化,導(dǎo)致選項改變,親愛的朋友,看了這個例子,你對ajax是不是也有了

  更好的認(rèn)識呢?

【ajax解決的下拉框的onchange問題】相關(guān)文章:

冬季裝修如何解決漏風(fēng)問題12-27

如何解決美甲的掉落問題11-29

小學(xué)解決問題應(yīng)用題07-31

國學(xué)教育存在的問題與解決方法01-13

班組長常見問題怎么解決10-20

企業(yè)中層管理存在的問題與解決方案06-11

CAD里的常見問題及解決方法07-19

如何解決高爾夫右曲球的問題02-22

聲樂學(xué)習(xí)常見問題及解決方法06-03

企業(yè)管理溝通的存在問題和解決對策03-31