欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

基于Ajax实现下拉框联动显示数据

程序员文章站 2023-11-09 19:34:46
公司做项目的时候,需要用到下拉框联动显示数据的功能,索性利用ajax来实现,看到时间比较充裕,就没去找demo自己去想方法写了。纯自己的想法,有些可能比较弱智,希望不要见笑...

公司做项目的时候,需要用到下拉框联动显示数据的功能,索性利用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=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实现下拉框联动显示数据有所帮助。