中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Ajax如何實現下拉框聯動顯示數據

發布時間:2021-06-25 10:59:56 來源:億速云 閱讀:159 作者:小新 欄目:web開發

小編給大家分享一下Ajax如何實現下拉框聯動顯示數據,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

頁面中的兩個下拉列表框:

<tr>
        <td >
          所在學院:</td>
        <td >
          <select id="college"  runat="server" onchange="changcollege(this.value)">
            <option value="0">
              --請選擇所在學院學院--
            </option>
          </select></td>
      </tr>
      <tr>
        <td >
          所在專業:</td>
        <td >
          <select id="specialty"  runat="server" onchange="SaveSpecical(this.value)">
            <option value="0">
              --請選擇所在專業--
            </option>
          </select></td>
      </tr>

JS腳本代碼:

<script type="text/javascript">
var http_request = false;
function send_request(method,url,content,responseType,callback)//定義發送請求的函數
{
  http_request=false;
  if(window.XMLHttpRequest)
  {
    http_request=new XMLHttpRequest();
    if(http_request.overrideMimeType)
    {
      http_request.overrideMimeType("text/xml");
    }
  }
  else
  {
    try
    {
      http_request=new ActiveXObject("Msxml2.XMLHTTP");
    }
    catch(e)
    {
      try
      {
        http_request=new ActiveXObject("Microsoft.XMLHTTP");
      }
      catch(e)
      {}
    }
  }
  if(!http_request)
  {
    window.alert("創建XMLHttpRequest對象失敗");
    return false;
  }
  if(responseType.toLowerCase()=="text")
  {
    http_request.onreadystatechange=callback;
  }
  else
  {
    window.alert("ERR");
    return false;
  }
  if(method.toLowerCase()=="get")
  {
    http_request.open(method,url,true);
  }
  else if(method.toLowerCase()=="post")
  {
    http_request.open(method,url,true);
    http_request.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
  }
  else
  {
    window.alert("Err");
    return false;
  }
  http_request.send(content);
}
function changcollege(va)//當學院下拉列表發生改變時觸發的腳本事件
{
  if(va!='0')
  {
    var speciality = document.getElementById("specialty");
    speciality.disabled=false;
    var url="Handler.ashx?type=college&id="+va;
    send_request("GET",url,null,"text",populateClass3);
  }
}
function populateClass3()//Ajax執行成功的回調函數
{
  var f=document.getElementById("specialty");
  if(http_request.readyState==4)
  {
      if(http_request.status==200)
      {
        var list=http_request.responseText;
        var classList=list.split("|");
        f.options.length=1;
        for(var i=0;i<classList.length;i++)
            //將取得的結果添加到下級的列表框中
        {
          var tmp=classList[i].split(",");
          f.add(new Option(tmp[1],tmp[0]));
        }
      }
      else
      {
        alert("您所請求的頁面有異常。");
      }
  }
}  
</script>

我們將http請求發送給服務端的Handler.ashx進行處理。

public class Handler : IHttpHandler 
{
  public void ProcessRequest(HttpContext context)
  {
    string type = context.Request.QueryString["type"];
    if (type.Equals("college"))
    {
      string id = context.Request.QueryString["id"];
      context.Response.ContentType = "text/plain";
      context.Response.Write(getSpecialty(id));//這個是從數據庫中根據傳來省的id 查詢出來的。學院的名字和主鍵,主鍵以便去查專業的名字
    }
  }
  public string getSpecialty(string college)
  {
    DataSet ds = GetInformation.GetSpecialtyInfo(college);
    string str = "";
    for (int i = 0; i < ds.Tables[0].Rows.Count; i++)
    {
      if (i == ds.Tables[0].Rows.Count - 1)
      {
        str += ds.Tables[0].Rows[i]["SpecialtyID"].ToString() + "," + ds.Tables[0].Rows[i]["SpecialtyName"].ToString();
      }
      else
      {
        str += ds.Tables[0].Rows[i]["SpecialtyID"].ToString() + "," + ds.Tables[0].Rows[i]["SpecialtyName"].ToString() + "|";
      }
    }
    return str.Trim();
  }
  public bool IsReusable {
    get {
      return false;
    }
  }
}

根據學院的編號獲得相應的專業,并將專業的名稱用“|”分割組合成字符串返回給客戶端,客戶端腳本拆分字符串添加到下拉框中。

Ajax如何實現下拉框聯動顯示數據

這里只是二級的聯動顯示,三級聯動數據的現實原理是一樣的。

以上是“Ajax如何實現下拉框聯動顯示數據”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

彰化市| 阜宁县| 嘉禾县| 临洮县| 兰坪| 兴文县| 彝良县| 临朐县| 海丰县| 福州市| 宁化县| 西乌| 东源县| 读书| 陆河县| 本溪| 泽州县| 长兴县| 夹江县| 房产| 缙云县| 仁化县| 北碚区| 雷山县| 和静县| 碌曲县| 贵阳市| 渑池县| 奉新县| 咸丰县| 莒南县| 乾安县| 彰化市| 来宾市| 全椒县| 高邑县| 西宁市| 黎川县| 南投县| 安阳市| 尖扎县|