Ajax实现下拉列表联动

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>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
项目:使用 JavaScript 编写的杀死幽灵游戏(附源代码) 杀死鬼魂游戏是使用 Vanilla JavaScript、CSS 和 HTML 画布开发的简单项目。这款游戏很有趣。玩家必须触摸/杀死游荡的鬼魂才能得分。您必须将鼠标悬停在鬼魂上 - 尽量得分。鬼魂在眨眼间不断从一个地方移动到另一个地方。您必须在 1 分钟内尽可能多地杀死鬼魂。 游戏制作 这个游戏项目只是用 HTML 画布、CSS 和 JavaScript 编写的。说到这个游戏的特点,用户必须触摸/杀死游荡的幽灵才能得分。游戏会根据你杀死的幽灵数量来记录你的总分。你必须将鼠标悬停在幽灵上——尽量得分。你必须在 1 分钟内尽可能多地杀死幽灵。游戏还会显示最高排名分数,如果你成功击败它,该分数会在游戏结束屏幕上更新。 该游戏包含大量的 javascript 以确保游戏正常运行。 如何运行该项目? 要运行此游戏,您不需要任何类型的本地服务器,但需要浏览器。我们建议您使用现代浏览器,如 Google Chrome 和 Mozilla Firefox。要玩游戏,首先,单击 index.html 文件在浏览器中打开游戏。 演示: 该项目为国外大神项目,可以作为毕业设计的项目,也可以作为大作业项目,不用担心代码重复,设计重复等,如果需要对项目进行修改,需要具备一定基础知识。 注意:如果装有360等杀毒软件,可能会出现误报的情况,源码本身并无病毒,使用源码时可以关闭360,或者添加信任。
javascript 中的 Paint War Game 是使用 HTML、CSS 和 JavaScript 开发的。谈到游戏玩法,这款游戏的主要目标是建造比敌人更多的油漆砖。您所要做的就是使用 WASD 键输入玩家的动作。您可以使用 VS Code 来运行该项目。 关于项目 每次您的玩家走过一块瓷砖时,它都会被涂成您的团队颜色。您必须在同一块瓷砖上走 4 次才能获得更多游戏点数。瓷砖会被您的团队挡住,并且不能再被偷走。如果您走过另一支球队的瓷砖,它会像您第一次走过时一样被涂上颜色。如果您创建一个封闭的被阻挡瓷砖图形,图形内所有未被阻挡的瓷砖都将固定为您的团队颜色。这个游戏充满乐趣,创造和重新即兴发挥会更有趣。 要运行此项目,我们建议您使用现代浏览器,例如 Google Chrome、  Mozilla Firefox。该游戏可能还支持 Explorer/Microsoft Edge。 演示: javascript 中的 Paint War Game 是使用 HTML、CSS 和 JavaScript 开发的。谈到游戏玩法,这款游戏的主要目标是建造比敌人更多的油漆砖。您所要做的就是使用 WASD 键输入玩家的动作。您可以使用 VS Code 来运行该项目。 关于项目 每次您的玩家走过一块瓷砖时,它都会被涂成您的团队颜色。您必须在同一块瓷砖上走 4 次才能获得更多游戏点数。瓷砖会被您的团队挡住,并且不能再被偷走。如果您走过另一支球队的瓷砖,它会像您第一次走过时一样被涂上颜色。如果您创建一个封闭的被阻挡瓷砖图形,图形内所有未被阻挡的瓷砖都将固定为您的团队颜色。这个游戏充满乐趣,创造和重新即兴发挥会更有趣。 要运行此项目,我们建议您使用现代浏览器,例如 Google Chrome、  Mozilla Firefox。该游戏可能还支持 Explorer/Microsoft Edge。 演示: 该项目为国外大神项目,可以作为毕业设计的项目,也可以作为大作业项目,不用担心代码重复,设计重复等,如果需要对项目进行修改,需要具备一定基础知识。 注意:如果装有360等杀毒软件,可能会出现误报的情况,源码本身并无病毒,使用源码时可以关闭360,或者添加信任。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值