1.什么是Ajax?
Ajax(Asynchronous JavaScript and XML),简单说就是不需要刷新当前页面而实现javaScript和和后台服务器交换数据以更新网页中的部分内容。
2. 实现
第一步: 创建 XMLHttpRequest 对象,老版的IE浏览器用 ActiveXObject 对象
var request; if (window.XMLHttpRequest){ // code for IE7+, Firefox, Chrome, Opera, Safari request = new XMLHttpRequest(); }else{// code for IE6, IE5 request = new ActiveXObject("Microsoft.XMLHTTP"); }
第二步:准备相关数据 , 调用 request.open();方法,
request.open(method,url);// method是请求方式:GET/POST,url是请求目标
第三步:调用request.send();方法
request.send(data);// data是通过此请求要发送的数据
第四步:为request对象的属性onreadystatechange添加响应函数,此函数由系统触发,然后根据响应状态做出相应的处理
request.onreadystatechange = function(){ // 判断响应是否完成 if(request.readyState == 4){ // 判断响应结果是否正常 if(request.status == 200 || request.status == 304){ /** request.responseText 或 request.responseXML 返回的数据,在这里做相应的处理 */ } } }
至此一次Ajax通信完成!
说明:响应的返回的数据格式有三种:
html 格式,不需解析,可以直接镶嵌到页面中——不太方便;
XML 格式, 通用数据格式,占用的空间较大,解析相对困难;
JSON 格式,占用空间较小,有面向对象的特点,且有第三方 jar 包可以将java对象或集合包装成JSON字符串。
3. 用JQuery实现Ajax操作
对于 html 或 text 格式的数据,可直接使用 $( selector).load();方法;
$(selector).load(url,args) // url 为请求的目标位置,默认的请求方式的GET,但args若作为第二参数时自动转换为POST方式,注意,args必须是JSON格式
这样返回的 responseText 会直接加载成 selector 对应节点的子元素。
对于XML格式和JSON格式则有 $.get(url,[args],[callback],[type]) 或 $.post(url,[args],[callback],[type]) 方法,args是要发送的数据,callback为回调函数,接受的数据在回调函数的参数 data 中,type是指以相应的数据格式接受数据;
// 这是用get方法接收XML格式的数据 $("a").click(function(){ // 为 a 标签添加 click 函数 var url = this.href; $.get(url,function(data){ // data的内容就是下面XML文档的内容 var name = $(data).find("name").text(); var website = $(data).find("website").text(); var email = $(data).find("email").text(); $("#content").empty().append("<h2><a href='mailto:"+email+"'>"+name+"</a></h2>") .append("<a href='"+website+"'>"+website+"</a>"); // 将数据加在 id 为 content 的节点下面 }); return false; // 取消 a 标签的默认操作 });
<?xml version="1.0" encoding="UTF-8"?> <details> <name>Andy Budd</name> <website>http://andybudd.com</website> <email>andy@clearleft.com</email> </details>
若是JSON数据,则可以用eval() 处理一下data,或者在get方法中加入 "JSON" 作为 type 参数,或直接调用$.getJSON() 方法,则得到的 data 就是一个JSON 对象。
$.get(url,args,function(data){ // data 是JSON对象 },"JSON"); $.post(url,args,function(data){ // data 是JSON对象 },"JSON"); $.getJSON(url,args,function(data){ // data 是JSON对象 });
然后根据页面的需要将数据更新到页面即可!