Ajax实现下拉列表联动
1.取得一级列表中的值,通过XMLHttpRequest发送给服务器;
2.服务器根据传入参数在内存或数据库中找到相应信息,返回给客户端;
3.客户端根据返回值更新二级列表。
select.html:
程序代码
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Select</title>
<script type="text/javascript" src="js/select.js"></script>
</head>
<body>
<h2>Select</h2>
<select id="first" onChange="change();">
<option value="">Please select</option>
<option value="J2EE">J2EE</option>
<option value="DataBase">DataBase</option>
<option value="Tools">Tools</option>
</select>
<select id="second">
<option value="">Please select</option>
</select>
</body>
</html>
select.js:
程序代码
var xmlHttp;
function createXMLHttpRequest() {
if (window.ActiveXObject) {
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
} else if (window.XMLHttpRequest) {
xmlHttp = new XMLHttpRequest();
}
}
function change() {
createXMLHttpRequest();
var first = document.getElementById("first").value;
var timeStamp = new Date().getTime();
var url = "select.mgc?first=" + first + "×tamp=" + timeStamp;
xmlHttp.onreadystatechange = callback;
xmlHttp.open("GET", url, true);
xmlHttp.send(null);
}
function callback() {
if (xmlHttp.readyState == 4) {
if (xmlHttp.status == 200) {
parseResult();
}
}
}
function parseResult() {
var xmlDoc = xmlHttp.responseXML;
var javas = xmlDoc.getElementsByTagName("java");
var second = document.getElementById("second");
second.length = 1;
for (var i = 0; i < javas.length; i++) {
var java = javas[i].childNodes[0].nodeValue;
var len = second.length;
second.options[len] = new Option(java, java);
}
}
select.html:
程序代码
package cn.edu.ahau.mgc.ajax.select;
import java.io.IOException;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class Select extends HttpServlet {
private List<Java> javas = new ArrayList<Java>();
@Override
public void init() throws ServletException {
super.init();
this.initData();
}
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
this.doPost(request, response);
}
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
request.setCharacterEncoding("UTF-8");
String first = request.getParameter("first");
List<Java> rsJavas = query(first);
String xml = "<javas>";
for (Iterator<Java> iter = rsJavas.iterator(); iter.hasNext();) {
Java java = (Java) iter.next();
xml += "<java>" + java.getSecond() + "</java>";
}
xml += "</javas>";
response.setContentType("text/xml");
PrintWriter out = response.getWriter();
out.print(xml);
out.close();
}
private List<Java> query(String first) {
List<Java> rsJavas = new ArrayList<Java>();
for (Iterator<Java> iter = javas.iterator(); iter.hasNext();) {
Java java = (Java) iter.next();
if (java.getFirst().equals(first)) {
rsJavas.add(java);
}
}
return rsJavas;
}
private void initData() {
javas.add(new Java("J2EE", "JSP"));
javas.add(new Java("J2EE", "Servlet"));
javas.add(new Java("J2EE", "Struts"));
javas.add(new Java("J2EE", "Hibernate"));
javas.add(new Java("J2EE", "Spring"));
javas.add(new Java("DataBase", "SQL Server"));
javas.add(new Java("DataBase", "MySQL"));
javas.add(new Java("DataBase", "Oracle"));
javas.add(new Java("DataBase", "DB2"));
javas.add(new Java("Tools", "NetBeans"));
javas.add(new Java("Tools", "MyEclipse"));
javas.add(new Java("Tools", "JBuild"));
}
class Java {
private String first;
private String second;
Java(String first, String second) {
this.first = first;
this.second = second;
}
public String getFirst() {
return first;
}
public void setFirst(String first) {
this.first = first;
}
public String getSecond() {
return second;
}
public void setSecond(String second) {
this.second = second;
}
}
}
web.xml:
程序代码
<?xml version="1.0" encoding="UTF-8"?>
<web-app version="2.4"
xmlns="http://java.sun.com/xml/ns/j2ee"
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://java.sun.com/xml/ns/j2ee
http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd">
<servlet>
<description>This is the description of my J2EE component</description>
<display-name>This is the display name of my J2EE component</display-name>
<servlet-name>Select</servlet-name>
<servlet-class>cn.edu.ahau.mgc.ajax.select.Select</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>Select</servlet-name>
<url-pattern>/select.mgc</url-pattern>
</servlet-mapping>
<welcome-file-list>
<welcome-file>index.jsp</welcome-file>
</welcome-file-list>
</web-app>
分享到:
相关推荐
使用ajax实现省,市(县),乡三级下拉列表联动.
jquery ajax xml 实现省市县下拉列表联动 加载全中国的省市县信息
基于Ajax的二级联动下拉列表.rar基于Ajax的二级联动下拉列表.rar基于Ajax的二级联动下拉列表.rar基于Ajax的二级联动下拉列表.rar基于Ajax的二级联动下拉列表.rar
用ajax实现的jsp二级联动下拉列表,使用异步交互的二级联动堪称jsp革命性变动。以前的联动大都是把所有的数据取出来放在javascript中,就一个字------烦
这是将《用Ajax实现多级联动下拉列表(无限级别,JSON传输数据,含全国地区数据库))》(原来是asp的)改写成ASP.NET,服务器端采用WebService。仍然使用JSON传数据。原文地址:...
ajax异步实现 两级联动下拉列表和分类显示数据,包含了JS+CSS的简单设计
servlet+ajax做的两个下拉列表联动(数据从数据库查出后显示到HTML上)
ajax 我们也就讲过一个小例子,这是后来经老师指点后用老师的例子改的,希望对想实现二级联动的同学有所帮助.
ajax 二级联动 php的下拉列表ajax 二级联动 php的下拉列表ajax 二级联动 php的下拉列表ajax 二级联动 php的下拉列表ajax 二级联动 php的下拉列表ajax 二级联动 php的下拉列表
用jquery、ajax读取json数据实现select列表的三级联动(下拉列表三级联动)
ajax不限层级下拉列表联动,附带源码和jar包及数据库。 开发人员可以按照需求自行修改数据连接。
自己jsp写的小实例,就两个jsp文件,一看就明白
dwr实现的完整的二级下拉联动列表,里面有说明,源代码。
这是将《用Ajax实现多级联动下拉列表(无限级别,JSON传输数据,含全国地区数据库))》(原来是asp的)改写成JSP。下载包中包含一个org.json.jar,测试的时候,请将这个包加了应用服务器的lib目录中,原文地址:...
帝国CMS二级联动插件(ajax下拉列表) 帝国CMS二级联动插件(ajax下拉列表).rar
NULL 博文链接:https://huigege.iteye.com/blog/1852954
ajax 下来联动列表城市选择 使用JAVA开发,大家可以下载下来看看
Ajax+PHP二级联动下拉列表(实现下拉联动)
Ajax城市 城镇联动下拉列表框
当二级联动要实现数据库时实读取时,比较麻烦,本例子用Ajax可以简单实现 ajax+Jsp+js+servlet