• <sub id="h4knl"><ol id="h4knl"></ol></sub>
    <sup id="h4knl"></sup>
      <sub id="h4knl"></sub>

      <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
      1. <strong id="h4knl"></strong>

      2. 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是不是也有了

          更好的認識呢?

        《&.doc》
        将本文的Word文档下载到电脑,方便收藏和打印
        推荐度:
        点击下载文档

        【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

        在线咨询
        国产高潮无套免费视频_久久九九兔免费精品6_99精品热6080YY久久_国产91久久久久久无码
      3. <sub id="h4knl"><ol id="h4knl"></ol></sub>
        <sup id="h4knl"></sup>
          <sub id="h4knl"></sub>

          <sub id="h4knl"><ol id="h4knl"><em id="h4knl"></em></ol></sub><s id="h4knl"></s>
          1. <strong id="h4knl"></strong>

          2. 亚洲激情在线中文 | 亚洲中文精品久久久久久 | 三级中文字幕在线视频 | 中文字幕乱码亚州无线码二区 | 久久亚洲精精品中文字幕 | 亚洲精品国产一卡二卡三 |

            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是不是也有了

              更好的認識呢?