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对象
});

 然后根据页面的需要将数据更新到页面即可!

 

posted on 2018-02-06 21:13  lightandtruth  阅读(150)  评论(0编辑  收藏  举报