本文主要是比较三种实现Ajax的方式
1、 prototype.js
2、 jquery1.3.2.min.js
3、 json2.js
后台处理程序(Servlet),访问路径servlet/testAjax:
package ajax.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;
/**
* Ajax例子后台处理程序
* @author bing
* @version 2011-07-07
*
*/
public class TestAjaxServlet extends HttpServlet {
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
response.setContentType("text/html;charset=utf-8");
PrintWriter out = response.getWriter();
String name = request.getParameter("name");
String age = request.getParameter("age");
System.out.println("{\"name\":\"" + name + "\",\"age\":\"" + age + "\"}");
out.print("{\"name\":\"" + name + "\",\"age\":" + age + "}");
out.flush();
out.close();
}
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException {
doGet(request,response);
}
}
TestAjaxServlet接收两个参数:name和age,并返回一个以JSON格式编写的字符串。
前台页面参数输入界面:
<div id="show">显示区域</div>
<div id="parameters">
name:<input id="name" name="name" type="text" /><br />
age:<input id="age" name="age" type="text" /><br />
</div>
一、prototype实现
<script type="text/javascript" src="prototype.js"></script>
<script type="text/javascript">
function prototypeAjax()
{
var url = "servlet/testAjax";//请求URL
var params = Form.serialize("parameters");//提交的表单
var myAjax = new Ajax.Request(
url,{
method:"post",// 请求方式
parameters:params, // 参数
onComplete:pressResponse, // 响应函数
asynchronous:true
});
$("show").innerHTML = "正在处理中...";
}
function pressResponse(request)
{
var obj = request.responseText; // 以文本方式接收
$("show").innerHTML = obj;
var objJson = request.responseText.evalJSON(); // 将接收的文本用解析成Json格式
$("show").innerHTML += "name=" + objJson['name'] + " age=" + objJson['age'];
}
</script>
<input id="submit" type="button" value="提交" onclick="prototypeAjax()" /><br />
在prototype的Ajax实现中,用evalJSON方法将字符串转换成JSON对象。
二、jquery实现
<script type="text/javascript" src="jquery-1.3.2.min.js"></script>
<script type="text/javascript" src="json2.js"></script>
<input id="submit" type="button" value="提交" /><br />
<script type="text/javascript">
function jqueryAjax()
{
var user={"name":"","age":""};
user.name= $("#name").val();
user.age=$("#age").val();
var time = new Date();
$.ajax({
url: "servlet/testAjax?time="+time,
data: "name="+user.name+"&age="+user.age,
datatype: "json",//请求页面返回的数据类型
type: "GET",
contentType: "application/json",//注意请求页面的contentType 要于此处保持一致
success:function(data) {//这里的data是由请求页面返回的数据
var dataJson = JSON.parse(data); // 使用json2.js中的parse方法将data转换成json格式
$("#show").html("data=" + data + " name="+dataJson.name+" age=" + dataJson.age);
},
error: function(XMLHttpRequest, textStatus, errorThrown) {
$("#show").html("error");
}
});
}
$("#submit").bind("click",jqueryAjax); // 绑定提交按钮
</script>
三、XMLHttpRequest实现
<script type="text/javascript">
var xmlhttp;
function XMLHttpRequestAjax()
{
// 获取数据
var name = document.getElementById("name").value;
var age = document.getElementById("age").value;
// 获取XMLHttpRequest对象
if(window.XMLHttpRequest){
xmlhttp = new XMLHttpRequest();
}else if(window.ActiveXObject){
var activxName = ["MSXML2.XMLHTTP","Microsoft.XMLHTTP"];
for(var i = 0 ; i < activexName.length; i++){
try{
xmlhttp = new ActiveXObject(activexName[i]);
break;
}catch(e){}
}
}
xmlhttp.onreadystatechange = callback; //回调函数
var time = new Date();// 在url后加上时间,使得每次请求不一样
var url = "servlet/testAjax?name="+name+"&age="+age+"&time="+time;
xmlhttp.open("GET",url,true); // 以get方式发送请求
xmlhttp.send(null); // 参数已在url中,所以此处不需要参送
}
function callback(){
if(xmlhttp.readyState == 4){
if(xmlhttp.status == 200){ // 响应成功
var responseText = xmlhttp.responseText; // 以文本方式接收响应信息
var userdiv = document.getElementById("show");
var responseTextJson = JSON.parse(responseText); // 使用json2.js中的parse方法将data转换成json格式
userdiv.innerHTML=responseText + " name=" + responseTextJson.name + " age=" + responseTextJson.age;
}
}
}
</script>
<input id="submit" type="button" value="提交" onclick="XMLHttpRequestAjax()" /><br />
分享到:
相关推荐
本文给大家介绍ajax的三种实现及json解析的相关资料,对本文感兴趣的朋友参考下
java生成json数据 ajax请求数据并解析json
jQuery_Ajax_Json全解析等相关文档集合
ajax解析json型的数据,2中方法,有列子,也有注释,很详细。新手可以学习一下。主要就是功能代码。
ajax 和 JSON2解析ajax 和 JSON2解析
Ajax 解析XML+json总结,很好的资源哦。欢迎大家来下载。
json解析文件ToJSP,如果使用JQuery的$.ajax()与servlet通信,就可以帮助你
此项目是基于springMVC实现的,基本流程为从前台jsp页面使用Ajax文件上传导入excel文件(.xls(97-03)/.xlsx(07以后)),传到后台controller调用相应工具类解析后返回指定参数做后续处理. 1. POIUtil.java工具类 解析...
运用Ajax技术,在XML、JSON中选择满足应用程序需求和功能、节省存储空间、易于生成和解析的数据格式成为WEB应用程序设计的关键。该文通过XML、JSON的介绍、实例运用及重要特征与环境支持区别的分析得出JSON是适用于...
json包含常用的解析方法,包含常用方法说明,包含ajax和json的搭配使用。。。。
ajax以json格式两种在服务端的解析方法 ,ajax以json格式两种在服务端的解析方法 。
主要介绍了javascript解析ajax返回的xml和json格式数据,结合实例形式详细分析了JS ajax调用及返回值中xml与json格式数据的处理技巧,需要的朋友可以参考下
国外专家写的,已压缩空白和注释,可用于生产。代码把json对象解析成html元素,对ajax应用有相当大的帮助。
lotus domino AJAX 代理print json
深入剖析AJAX 解析JSON数据格式 抚尺而已 之,一人、一桌、一椅、一扇、一 忽然抚尺一下,群响毕绝。撤屏视
主要介绍了jQuery使用ajax方法解析返回的json数据功能,结合实例形式分析了jQuery ajax操作流程及json数据处理技巧,需要的朋友可以参考下
struts2+json开发所需类
ASP 解析AJAX提交的JSON数据的实例