利用jaxp、dom实现ajax xml 响应

本文介绍了一种使用Ajax技术实现网页中联动下拉框的方法。通过配置web-inf文件中的servlet,创建JSP页面并设计SelectServlet类来处理请求,生成XML响应,从而实现动态更新下拉选项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

<iframe width="336" scrolling="no" height="280" frameborder="0" allowtransparency="true" hspace="0" vspace="0" marginheight="0" marginwidth="0" src="http://pagead2.googlesyndication.com/pagead/ads?client=ca-pub-1832179689702023&amp;dt=1183008743078&amp;lmt=1179059997&amp;format=336x280_as&amp;output=html&amp;correlator=1183008743078&amp;channel=7111701428&amp;url=http%3A%2F%2Fwww.java3z.com%2Fcwbwebhome%2Farticle%2Farticle5%2F5594.html%3Fid%3D948&amp;color_bg=FFFFFF&amp;color_text=000000&amp;color_link=0000FF&amp;color_url=3D81EE&amp;color_border=FFFFFF&amp;ad_type=text_image&amp;ref=http%3A%2F%2Fwww.google.cn%2Fsearch%3Fcomplete%3D1%26hl%3Dzh-CN%26newwindow%3D1%26q%3DAJAX%2BXML%26btnG%3DGoogle%2B%25E6%2590%259C%25E7%25B4%25A2%26meta%3D&amp;cc=52&amp;flash=9&amp;u_h=800&amp;u_w=1280&amp;u_ah=770&amp;u_aw=1280&amp;u_cd=32&amp;u_tz=480&amp;u_his=1&amp;u_java=true&amp;u_nplug=13&amp;u_nmime=50" name="google_ads_frame"></iframe>

DocumentBuilderFactory factory = DocumentBuilderFactory. newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();

Document doc = builder.newDocument();
创建root元素 或其它元素 Element root = doc.createElement("selects");

doc.appendChild(root);
Element的appendChild()方法用来添加子元素

创建文本结点 doc.createTextNode(String textNode)

在servlet中 通过以下方法转换到输出流
Transformer t = TransformerFactory.newInstance().newTransformer();
t.transform(new DOMSource(doc), new StreamResult(response.getWriter()));

一、 web.inf 文件配置一个servlet
<?xml version="1.0" encoding="ISO-8859-1"?>

<web-app 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"
version="2.4">

<display-name>Welcome to Tomcat</display-name>
<description>
Welcome to Tomcat
</description>

<servlet>
<servlet-name>SelectServlet</servlet-name>
<servlet-class>drownmenu.SelectServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>SelectServlet</servlet-name>
<url-pattern>/SelectServlet</url-pattern>
</servlet-mapping>
</web-app>

二、JSP页面
<%@ page language="java" contentType="text/html; charset=utf-8"%>

<html>
<head>
<title>Ajax 联动下拉框</title>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<SCRIPT type="text/javascript">


 </script>
</head>

<body>
<div align="center">
<form name="form1" method="post" action="">
<TABLE width="70%" boder="0" cellspacing="0">
<TR>
<TD align="center">Ajax 联动下拉框</TD>
</TR>
<TR>
<TD>请选择省份:

<SELECT name="state" id="state" onChange="Change_Select()">
<OPTION value="0">未选择</OPTION>
<OPTION value="1">湖南</OPTION>
<OPTION value="2">湖北</OPTION>
</SELECT>

请选择城市:
<SELECT name="city" id="city">
<OPTION value="0">未选择</OPTION>
</SELECT>
</TD>
</TR>
<TR><td>&nbsp;</td></TR>
</TABLE>
</form>
</div>
</body>
</html>

三、 SelectServlet 类
package drownmenu;

import javax.servlet.*;
import javax.servlet.http.*;
import java.io.*;
import java.util.*;
import javax.xml.parsers.*;
import org.w3c.dom.*;
import javax.xml.transform.*;
import javax.xml.transform.stream.*;
import javax.xml.transform.dom.*;

public class SelectServlet extends HttpServlet {

//Initialize global variables
public void init() throws ServletException {
}

//Process the HTTP Get request
public void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
String targetId = request.getParameter("id").toString();
response.setCharacterEncoding("UTF-8");
response.setContentType("application/xml");
try {
DocumentBuilderFactory factory = DocumentBuilderFactory. newInstance();
DocumentBuilder builder = factory.newDocumentBuilder();
Document doc = builder.newDocument();

Element root = doc.createElement("selects");
doc.appendChild(root);

/*
String xml_start="<selects>";
String xml_end="</selects>";
String xml="";
*/

if (targetId.equalsIgnoreCase("0")) {
makeElement(doc, root, new String[] {"未选择"});
// xml = "<select><value>0</value><text>Unbounded</text></select>";
}
if (targetId.equalsIgnoreCase("1")) {
makeElement(doc, root, new String[] {"长沙","岳阳"});

/* xml ="<select><value>1</value><text>Mana Burn</text></select>";
xml +="<select><value>2</value><text>Death Coil</text></select>";
xml +="<select><value>3</value><text>Unholy Aura</text></select>";
xml +="<select><value>4</value><text>Unholy Fire</text></select>";
*/
}

if (targetId.equalsIgnoreCase("2")) {
makeElement(doc, root, new String[] {"武汉","石堰","襄樊","孝感"});
/*
xml ="<select><value>1</value><text>Corprxplode</text></select>";
xml +="<select><value>2</value><text>Raise Dead</text></select>";
xml +="<select><value>3</value><text>Brilliance Aura</text></select>";
xml +="<select><value>4</value><text>Aim Aura</text></select>";
*/
} //else {
// makeElement(doc, root, new String[] {"何畅1", "何畅2", "何畅3"});
/*
xml ="<select><value>1</value><text>Rain of Chaos</text></select>";
xml +="<select><value>2</value><text>Finger of Death</text></select>";
xml += "<select><value>3</value><text>Bash</text></select>";
xml +="<select><value>4</value><text>Summon Doom</text></select>";
*/
// }

Transformer t = TransformerFactory.newInstance().newTransformer();
t.transform(new DOMSource(doc), new StreamResult(response.getWriter()));

} catch (Exception ex) {
throw new ServletException(ex.toString());
}
// String last_xml = xml_start + xml + xml_end;
// response.getWriter().write(last_xml);
}

private void makeElement(Document doc, Element root, String[] name) throws  DOMException {
if (name == null) {
return;
}

for (int i = 0; i < name.length; i++) {
Element selectElement = doc.createElement("select");
root.appendChild(selectElement);

Element valueElement = doc.createElement("value");
Element textElement = doc.createElement("text");
int t=i+1;
Text valueText = doc.createTextNode(""+t);
Text textText = doc.createTextNode(name[i]);
valueElement.appendChild(valueText);
textElement.appendChild(textText);
selectElement.appendChild(valueElement);
selectElement.appendChild(textElement);
}

}

//Process the HTTP Post request
public void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
doGet(request, response);
}

//Clean up resources
public void destroy() {
}
}

运行图:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值