优点:异步交互,用户感觉不到页面的提交,当然也不等待页面返回。
响应速度快。
复杂的UI成功处理,一直以来,我们对B/S模式的UI不如C/S模式UI丰富而苦恼,现在由于AJAX大量使用JS,使得复杂的UI设计变得更加成功。
最后AJAX请求的返回对象为XML文件,易于和WEB SERVICE结合起来。
基于Servlet为后台的一个web应用例子:
关于关联选择框的问题:
当用户在第一个选择框里选择ZHEJIANGS时,第二个选择框要出现ZHEJIANG的城市;当用户在第一个选择框里选择JIANGSU时,第二个选择框里要出现JIANGSU的城市
首先,配置文件web.xml,在里面配置servlet,跟往常一样:
<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>
<servlet-name>SelectCityServlet</servlet-name>
<servlet-class>com.stephen.servlet.SelectCityServlet</servlet-class>
</servlet>
<servlet-mapping>
<servlet-name>SelectCityServlet</servlet-name>
<url-pattern>/servlet/SelectCityServlet</url-pattern>
</servlet-mapping>
</web-app>
JSP文件:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>MyHtml.html</title>
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<!--link rel="stylesheet" type="text/css" href="./style.css">HTML显式注释-->
</head>
<script type="text/javascript">
function getResult(stateVal){
var url = "servlet/ServletCityServlet?state="+stateVal;
if(window.XMLHttpRequest){//code for all new browsers
req = new XMLHttpRequest();
}else if(window.ActiveXObject){//code for IE5 IE6
req = new ActiveXObject("Microsoft.XMLHTTP");
}
if(req){
req.open("GET",url,true);
req.onreadystatechange = complete;
req.send(null);
}
}
function complete(){
if(req.readyState == 4){//4 = "loaded"
if(req.status == 200){//200 = OK
var city = req.responseXML.getElementsByTagName("city");
//alert(city.length)
var str = new Array();
for(var i=0;i<city.length;i++){
str[i]=city[i].firstChild.data;
}
//alert(document.getElementById("city"));
buildSelect(str,document.getElementById("city"));
}
}
}
function buildSelect(str,sel){
sel.options.length=0;
for(var i=0;i<str.length;i++){
sel.options[sel.options.length] = new Option(str[i],str[i])
}
}
</script>
<body>
<select name="state" onChange="getResult(this.value)">
<option value="">Select</option>
<option value="zj">ZEHJIANG</option>
<option value="js">JIANGSU</option>
</select>
<select id="city">
<option value="">CITY</option>
</select>
</body>
</html>
JS的不同
getResult(stateVal)方法,取得XmlHttpRequest;然后设置该请求的url:req.open("GET",url,true);接着设置请求返回值的接收方法:req.onreadystatechange = complete;该返回值的接收方法为 complete();最后是发送请求:req.send(null);
然后是返回值接收方法:complete(),这个方法,首先判断是否正确返回,如正确返回,用DOM对返回的XML文件进行解析。得到city值后,再通过buildSelect(str,sel)方法赋值到相应的选择框里面。
onreadystatechange是一个事件句柄,他的值complete是一个函数名称,当XMLHttpRequest对象的状态发生改变时,会触发此函数。状态从0到4进行变化。仅在状态为4时,才执行代码。
为什么使用Async=true?
open()的第三个参数中使用了"true"
该参数规定请求是否异步处理。
True表示脚本会在send()方法之后继续运行,而不等待来自服务器的响应。
onreadystatechange事件使代码复杂化了。但是这是在没有得到服务器响应的情况下,防止代码停止的最安全的方法。
通过把该参数设置为"false",可以省去额外的onreadystatechange代码。如果在请求失败时是否执行其余的代码无关紧要,那么就可以使用这个参数。
Servlet:
import java.io.IOException;
import java.io.PrintWriter;
import javax.servlet.ServletException;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
public class SelectCityServlet extends HttpServlrt{
public SelectCityServlet(){
super();
}
public void destory(){
super.destory();
}
public void doGet(HttpServletRequest request,HttpServletResponse
response)throws ServletException IOException{
response.setContentType("text/xml");
response.setHeader("Cache-Control","no-cache");
String state = request.getParamter("state");
StringBuffer sb = new StringBuffer("<state>");
if("zj".equals(state)){
sb.append("<city>hangzhou</city><city>huzhou</city>");
}else if("js".equals(state)){
sb.append("<city>nanjing</city><city>wuxi</city>");
}
sb.append("</state>");
PrintWriter out = response.getWriter();
out.write(sb.toString());
//out.write只能输出字符串,out.print可以输出Java对象
out.close;
}
}
这个类,首先是从request里取得state参数,然后根据state参数生成相应的XML文件,最后将XML文件输出到PrintWriter对象里。
分享到:
相关推荐
基于jsp+servlet+ajax的图书管理系统基于jsp+servlet+ajax的图书管理系统 基于jsp+servlet+ajax的图书管理系统基于jsp+servlet+ajax的图书管理系统 基于jsp+servlet+ajax的图书管理系统基于jsp+servlet+ajax的图书...
基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统源码.zip基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统源码.zip基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统源码.zip基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统...
作业:用户登录注册系统,后台采用jsp + servlet + javabean技术实现,浏览器客户端采用ajax框架之jquery框架! 要求: 不能抄袭,没有分组,面向接口编程,不要迟到! 1、注册的信息: 用户名,密码,性别(下拉...
直接进入TestAjax就可以自动找到欢迎页面。
基于Servlet和Ajax实现搜索框智能提示
作业:用户登录注册系统,后台采用jsp + servlet + javabean技术实现,浏览器客户端采用ajax框架之jquery框架! 要求: 不能抄袭,没有分组,面向接口编程,不要迟到! 1、注册的信息: 用户名,密码,性别(下拉...
Ajax+Servlet 实例 如何创建IE7兼容的AJAX请求 乱码解决
使用servlet+ajax实现无刷新发言与更新实时聊天记录以及注册时文本框失去焦点AJAX验证用户名是否已重复; 系统支持双人聊天与群聊,群聊登陆界面为webLogin.jsp 双人聊天为login.jsp。在注册以后均可以登陆系统进行...
基于Ajax技术的网页聊天工具。mysql数据库。有点像WEB QQ一样。前台用javaScript和Jquery库完成。后台java
基于Servlet+JSP+Jquery+EL+Ajax的餐饮管理系统.zip 1、该资源内项目代码经过严格调试,下载即用确保可以运行! 2、该资源适合计算机相关专业(如计科、人工智能、大数据、数学、电子信息等)正在做课程设计、期末大...
【资源说明】 1、该资源包括项目的全部源码,下载可以直接使用! 2、本项目适合作为计算机、数学、电子信息等专业的课程设计、期末大作业和...基于ajax+jsp+servlet+mysql利用IDEA实现的图书管理系统源码+数据库.zip
基于servlet+struts2+ajax+mysql开发的web聊天室
一个小例子,很简单的聊天室.. servlet负责处理客户端发来的信息和返回内容,jsp负责显示.ajax在jsp中实现无刷新提交. 解压后是eclipse的工程文件夹
基于 jsp + servlet + jquery + easy-ui + ajax 的学生成绩管理系统 基于 jsp + servlet + jquery + easy-ui + ajax 的学生成绩管理系统 基于 jsp + servlet + jquery + easy-ui + ajax 的学生成绩管理系统 基于 jsp...
基于 Java Web+JavaScript+JavaBean+Servlet+Ajax的企业信息管理系统.采用MySQL数据库.是很有价值的J2EE学习的入门案例分析-Based on Java Web+ JavaScript+ JavaBean+ Servlet+ Ajax for enterprise information ...
基于mysql数据库,通过ajax来传值到Servlet控制dao层方法进行购物车的商品添加和减少数量以及结算,
基于MVC用JSPServlet实现JPetStore实验报告+使用AJAX和jQuery改善用户体验实验报告
jsp,java web开发,毕业设计,课程设计作业,servlet框架,mysql数据库,源码资源
所用技术:jsp/servlet,html,javascript,struts,hibernate,css,div 开发工具:myeclipse,tomcat,oracle10g 项目描述:实现网上购物 主要工能:用户登录,用户的注册,商品的分页显示,商品的模糊查询,
基于java+servlet,mysql实现web系统,适合应用于毕业设计,课程设计作业,系统均完全测试通过,可直接运行! 基于java+servlet,mysql实现web系统,适合应用于毕业设计,课程设计作业,系统均完全测试通过,可直接...