校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > 基于Ajax實現下拉框聯動顯示數據

基于Ajax實現下拉框聯動顯示數據

熱門標簽:老虎郵局地圖標注點 襄陽外呼系統接口 科智聯智能電銷機器人 外呼系統獲取客戶手機號 上海浦東百度地圖標注中心注冊 百靈鳥 青海醫療智能外呼系統怎么樣 目標三維地圖標注 徐州電銷卡外呼系統供應商

公司做項目的時候,需要用到下拉框聯動顯示數據的功能,索性利用Ajax來實現,看到時間比較充裕,就沒去找demo自己去想方法寫了。純自己的想法,有些可能比較弱智,希望不要見笑。

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

tr>
        td style="width: 130px">
          所在學院:/td>
        td style="width: 100px">
          select id="college" style="width: 200px" runat="server" onchange="changcollege(this.value)">
            option value="0">
              --請選擇所在學院學院--
            /option>
          /select>/td>
      /tr>
      tr>
        td style="width: 130px">
          所在專業:/td>
        td style="width: 100px">
          select id="specialty" style="width: 200px" 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=collegeid="+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;iclassList.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三級聯動下拉菜單效果
  • AJAX省市區三級聯動下拉菜單(java版)
  • ThinkPHP使用心得分享-ThinkPHP + Ajax 實現2級聯動下拉菜單
  • JavaScript Ajax Json實現上下級下拉框聯動效果實例代碼
  • AJAX解析XML實例之下拉框省、市二級聯動
  • jquery ajax實現下拉框三級無刷新聯動,且保存保持選中值狀態
  • ajax讀取數據庫內容實現二級聯動下拉選擇菜單示例
  • Ajax實現無刷新三聯動下拉框
  • Jquery+ajax+JAVA(servlet)實現下拉菜單異步取值
  • Ajax+Servlet實現無刷新下拉聯動效果

標簽:辛集 揭陽 荊州 佛山 紅河 咸寧 商洛 股票

巨人網絡通訊聲明:本文標題《基于Ajax實現下拉框聯動顯示數據》,本文關鍵詞  基于,Ajax,實現,下拉,框,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《基于Ajax實現下拉框聯動顯示數據》相關的同類信息!
  • 本頁收集關于基于Ajax實現下拉框聯動顯示數據的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 瑞昌市| 峨边| 玉门市| 五台县| 环江| 古田县| 武强县| 建德市| 金塔县| 定州市| 集安市| 蓬溪县| 上犹县| 平舆县| 江达县| 上杭县| 临汾市| 古蔺县| 霸州市| 兴化市| 龙川县| 虹口区| 阳春市| 乌苏市| 九龙城区| 浮山县| 新巴尔虎左旗| 浑源县| 南京市| 桐柏县| 蕲春县| 新沂市| SHOW| 阿拉尔市| 营山县| 肃南| 达拉特旗| 泰和县| 铜川市| 浪卡子县| 伊吾县|