与此不同,AJAX应用可以仅向服务器发送并取回必需的数据,它使用SOAP或其它一些基于XML的web service接口,并在客户端采用JavaScript处理来自服务器的响应。因为在服务器和浏览器之间交换的数据大量减少,结果我们就能看到响应更快的应用。同时很多的处理工作可以在发出请求的客户端机器上完成,所以Web服务器的处理时间也减少了。
不说那么多废话了,直接入题:
首先,写jsp页面:
<%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding="UTF-8"%>
<%@ taglib prefix="ww" uri="/webwork" %>
<%
String path=request.getContextPath();
%>
<!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>TimeCard Manager Platform</title>
<script src="<%=path%>/js/prototype.js"></script>
<script>
function getXML(){
//局部请求地址
var url="searchAction.action";
//获取用户当前输入的内容
var inputvalue=document.getElementById("itext").value;
//使用prototype函数构造xmlhttprequest对象
var myAjax = new Ajax.Request(
url,
{
//请求方法为post
method:'post',
//设置参数为 inputtext=inputtext
parameters:"inputtext="+inputvalue,
//设置回调函数
onComplete:showResponse,
//是否异步
asynchronous:true
}
);
}
function showResponse(xmlrequest){
//回调函数
var text = xmlrequest.responseText;
//将匹配的内容输出到 span 层
document.getElementById("projectspan").innerHTML=text;
// $("projectspan").innerHTML=xmlrequest.responseText;
}
</head>
<body>
Project manager:
<span id="projectspan" class="font_bluet"> <select
name="project.resource_id" id="prijectmanager">
<option value="-1"> Choose</option>
<option value="0" >aaaa</option>
<option value="1" >bbbb</option>
<option value="2" >cccc</option>
<option value="3" >dddd</option>
</select> </span>
<input name="text" type="text" id="itext" onKeyUp="getXML()" />
</body>
</html>
在XWORK.XML中加入下面的代码:
<action name="searchAction" method="searchAction" class="com.mdcl.timecard.action.ProjectAction" >
</action>
在action中:
public void searchAction() {
HttpServletResponse response=ServletActionContext.getResponse();
response.setContentType("text/html;charset=utf-8");
PrintWriter out;
String inputtext = ServletActionContext.getRequest().getParameter("inputtext");
//根据输入框的内容到数据库查询符合条件项,返回
// List (resourcelist1)
//如果没有符合条件项,则查询所有列表,返回 List (resourcelist)
if(!resourcelist1.isEmpty() || resourcelist1.size()>0){
try {
out = ServletActionContext.getResponse().getWriter();
out.println("<select name='project.resource_id' id='prijectmanager' class='fram'>");
for(int i=0;i<resourcelist1.size();i++){
out.println("<option value=" + resourcelist1.get(i).getResourceId() + ">"
+ resourcelist1.get(i).getName() + "</option>");
}
out.println("</select>");
//输出缓存字符串
out.flush();
out.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}else{
try {
out = ServletActionContext.getResponse().getWriter();
out.println("<select name='project.resource_id' id='prijectmanager' class='fram'>");
for(int i=0;i<resourcelist.size();i++){
out.println("<option value=" + resourcelist.get(i).getResourceId() + ">"
+ resourcelist.get(i).getName() + "</option>");
}
out.println("</select>No Information!");
//输出缓存字符串
out.flush();
out.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
相关推荐
实例67 AjaX实现数据记录排序 实例68 局部动态更新数据 实例69 AjaX+PHP数据分页显示 实例70 指定CSS样式显示数据 实例71 JSON格式处理信息 第9章 Ajax时尚技术 实例72 根据邮编自动完成地址信息 实例73 AiaX...
Ajax的关键组件包括XMLHttpRequest对象、JavaScript、DOM(Document Object Model)和CSS,它们共同协作实现了页面的局部更新。 **JSP与Ajax结合** 1. **数据交换**:JSP通常用于处理服务器端的业务逻辑和数据操作...
在Ajax控件方面,它们通常是一些JavaScript库或框架,如jQuery、Prototype、Dojo、ExtJS等提供的组件,帮助开发者更容易地实现Ajax功能。例如,jQuery中的`$.ajax()`函数是实现Ajax请求的基础,它可以处理GET和POST...
- **实时搜索**:搜索框中的输入会触发AJAX请求,即时显示相关地点的预览结果。 3. **Gmail的AJAX创新** - **无刷新邮件查看**:Gmail通过AJAX实现了邮件的即时加载和预览,用户可以无需跳转页面查看邮件详情。 ...
- 实时搜索:用户在搜索框输入时,无需提交表单即可实时显示匹配结果。 - 数据表格分页:在不刷新整个页面的情况下,切换表格的页码以加载不同数据。 - 表单验证:在客户端进行表单数据验证,减少无效的服务器请求。...
2. **动态更新**:通过Ajax调用JSP,获取服务器返回的数据,动态更新DOM元素,实现局部刷新。 3. **回调函数**:Ajax请求的success或error回调函数处理服务器响应,可能涉及JSP产生的数据解析和页面更新。 **第九章...
服务器接收到请求后处理数据,返回结果,JavaScript再通过回调函数解析这些数据,并更新DOM树,实现局部刷新。Ajax的优点包括提升用户体验,减少网络流量,以及简化前后端交互流程。 二、Ajax应用实例 Ajax广泛应用...
6. **局部刷新**:使用DOM操作,如`innerHTML`属性,将接收到的数据插入到页面的特定位置,实现局部刷新。 7. **AJAX库与框架**:jQuery、Prototype、AngularJS等提供了更方便的AJAX接口,简化了开发过程。例如,...
1.本书1~16章所附代码的运行环境 ...程序描述:本章将仿照Google Suggest,使用Ajax技术实现动态获取搜索提示的功能。当输入搜索关键字时,自动向服务器发送请求,查询相关的关键字,并及时提示用户可输入的关键字。 ...
5. **局部刷新**:Ajax允许开发者只更新页面的特定部分,而不是整个页面。这减少了网络带宽的使用,提高了页面加载速度,提升了用户体验。 6. **跨域问题**:由于同源策略的限制,Ajax请求通常只能向同一源的服务器...
当用户在搜索框中输入时,JavaScript会发送当前的查询字符串到search.php。这个PHP文件会根据查询内容在数据库或其他数据源中查找匹配项,然后返回一个包含搜索建议的数据格式,通常是JSON或XML。返回的数据将被...
4. **项目实例分析**:压缩包中的3个Ajax项目实例可能是用来展示不同的应用场景,比如动态加载数据、无刷新表单提交、实时聊天等。通过研究这些实例,我们可以深入理解Ajax如何在实际项目中应用,包括如何构造请求,...
书中结合实际案例,展示了Ajax在不同场景下的应用,如实时搜索建议、分页加载、表单无刷新提交等。这些实例有助于读者将理论知识转化为实践能力,理解如何在实际项目中有效地运用Ajax。 五、J2EE环境下的Ajax 由于...
Prototype库通常会提供一套完整的Ajax解决方案,允许开发者在不刷新整个页面的情况下与服务器进行异步交互,包括发送请求、处理响应和更新DOM。 通过这个Prototype demo,开发者可以学习到如何利用Prototype库来...
它通过在后台与服务器进行少量数据交换,使网页实现局部刷新,从而极大地提升了用户体验。本教程源代码是针对Ajax技术的基础学习,涵盖了从基础概念到实际应用的各种示例。 在《Ajax.基础教程》中,你会学到以下几...
**AjaxDemo**是一个示例项目,它展示了在Web开发中如何使用AJAX(Asynchronous JavaScript and XML)技术来实现异步数据交互和页面无刷新更新。这个项目可能包含了一系列使用AJAX的实例,用于演示如何在.NET、ASP...
《Ajax实战(Ajax in action中文版)》提供的源码示例(AjaxInActionSourceCode)涵盖了各种实际应用场景,如实时搜索、无限滚动、表单验证等,读者可以通过实践这些例子深入理解Ajax技术。 综上所述,Ajax技术为网页...
3) 可以实现局部刷新,使得页面操作更加流畅。 缺点:1) 不利于搜索引擎优化,因为搜索引擎爬虫无法执行JavaScript;2) 安全性问题,如XSS(跨站脚本攻击)和CSRF(跨站请求伪造);3) 不支持浏览器的前进/后退功能...