基于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实现下拉框联动显示数据有所帮助。
上一篇: Cisco路由器的初始配置详细解读