欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

基于Ajax實(shí)現(xiàn)下拉框聯(lián)動顯示數(shù)據(jù)

 更新時間:2015年09月09日 10:27:27   投稿:mrr  
本篇文章給大家介紹基于ajax實(shí)現(xiàn)下拉框聯(lián)動顯示數(shù)據(jù),代碼非常簡單,需要的朋友可以參考下

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

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

<tr>
        <td style="width: 130px">
          所在學(xué)院:</td>
        <td style="width: 100px">
          <select id="college" style="width: 200px" runat="server" onchange="changcollege(this.value)">
            <option value="0">
              --請選擇所在學(xué)院學(xué)院--
            </option>
          </select></td>
      </tr>
      <tr>
        <td style="width: 130px">
          所在專業(yè):</td>
        <td style="width: 100px">
          <select id="specialty" style="width: 200px" runat="server" onchange="SaveSpecical(this.value)">
            <option value="0">
              --請選擇所在專業(yè)--
            </option>
          </select></td>
      </tr>

JS腳本代碼:

<script type="text/javascript">
var http_request = false;
function send_request(method,url,content,responseType,callback)//定義發(fā)送請求的函數(shù)
{
  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("創(chuàng)建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)//當(dāng)學(xué)院下拉列表發(fā)生改變時觸發(fā)的腳本事件
{
  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執(zhí)行成功的回調(diào)函數(shù)
{
  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++)
            //將取得的結(jié)果添加到下級的列表框中
        {
          var tmp=classList[i].split(",");
          f.add(new Option(tmp[1],tmp[0]));
        }
      }
      else
      {
        alert("您所請求的頁面有異常。");
      }
  }
}  
</script>

我們將http請求發(fā)送給服務(wù)端的Handler.ashx進(jìn)行處理。

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));//這個是從數(shù)據(jù)庫中根據(jù)傳來省的id 查詢出來的。學(xué)院的名字和主鍵,主鍵以便去查專業(yè)的名字
    }
  }
  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;
    }
  }
}

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

這里只是二級的聯(lián)動顯示,三級聯(lián)動數(shù)據(jù)的現(xiàn)實(shí)原理是一樣的。

本文的全部內(nèi)容就到此結(jié)束了,希望大家學(xué)習(xí)Ajax實(shí)現(xiàn)下拉框聯(lián)動顯示數(shù)據(jù)有所幫助。

相關(guān)文章

  • 淺談Bootstrap的DatePicker日期范圍選擇

    淺談Bootstrap的DatePicker日期范圍選擇

    下面小編就為大家?guī)硪黄獪\談Bootstrap的DatePicker日期范圍選擇。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • AJAX的跨域問題解決方案

    AJAX的跨域問題解決方案

    跨域簡單的說,就是從一個域名的網(wǎng)頁去訪問另一個域名網(wǎng)頁的資源,下面這篇文章主要給大家介紹了關(guān)于AJAX的跨域問題解決的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • ASP+AJAX+ACCESS數(shù)據(jù)庫實(shí)例講解三個步驟分享

    ASP+AJAX+ACCESS數(shù)據(jù)庫實(shí)例講解三個步驟分享

    其實(shí)說起AJAX的初級應(yīng)用是非常簡單的,通俗的說就是客戶端(javascript)與服務(wù)端(asp或php等)腳本語言的數(shù)據(jù)交互
    2012-07-07
  • 有關(guān)Ajax跨域問題的兩種解決方法

    有關(guān)Ajax跨域問題的兩種解決方法

    ajax本身實(shí)際上是通過XMLHttpRequest對象來進(jìn)行數(shù)據(jù)的交互,而瀏覽器出于安全考慮,不允許js代碼進(jìn)行跨域操作,會警告,所以才出現(xiàn)ajax跨域的問題。
    2015-10-10
  • ajax簡介_動力節(jié)點(diǎn)Java學(xué)院整理

    ajax簡介_動力節(jié)點(diǎn)Java學(xué)院整理

    這篇文章主要為大家詳細(xì)介紹了ajax基礎(chǔ)知識點(diǎn),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-06-06
  • 用 ajax 的方法解決網(wǎng)頁廣告顯示的問題

    用 ajax 的方法解決網(wǎng)頁廣告顯示的問題

    用 ajax 的方法解決網(wǎng)頁廣告顯示的問題...
    2006-12-12
  • ajax實(shí)現(xiàn)的提交文章前進(jìn)行敏感詞審核的代碼

    ajax實(shí)現(xiàn)的提交文章前進(jìn)行敏感詞審核的代碼

    在做“文章敏感詞匯審核”功能的時候,開始在把“審核”放在插入數(shù)據(jù)庫的時候,后來想有一個功能,能在用戶點(diǎn)擊“提交”按鈕的時候,給一個提示。這樣相對“友好”那么點(diǎn)。
    2010-02-02
  • Ajax與mysql數(shù)據(jù)交互實(shí)現(xiàn)留言板功能

    Ajax與mysql數(shù)據(jù)交互實(shí)現(xiàn)留言板功能

    最近自己做了一個小demo,實(shí)現(xiàn)了Ajax與MySQL的數(shù)據(jù)交互,js部分用的是jq,后臺用的是PHP,數(shù)據(jù)庫是mysql,下面通過本文給大家詳細(xì)介紹下
    2016-12-12
  • 關(guān)于IE下AJAX的問題探討

    關(guān)于IE下AJAX的問題探討

    在IE下,AJAX請求得到響應(yīng)后,回調(diào)函數(shù)onreadystatechange是在全局環(huán)境下被調(diào)用的,而在標(biāo)準(zhǔn)瀏覽器下,其執(zhí)行上下文是XMLHttpRequest對象
    2014-03-03
  • Ajax實(shí)現(xiàn)二級聯(lián)動菜單

    Ajax實(shí)現(xiàn)二級聯(lián)動菜單

    這篇文章主要為大家詳細(xì)介紹了Ajax實(shí)現(xiàn)二級聯(lián)動菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-11-11

最新評論