1.概念

Ajax是Asynchronous JavaScript and XML的缩写,就是异步JavaScript与XML。

传统WEB应用中,页面中用户的每一次操作都将触发一次返回Web服务器的HTTP请求,服务器进行相应处理后返回相应的HEML页面。而在Ajax应用中,页面中用户的操作将通过Ajax

引擎与服务器端进行通信,然后将返回结果提交给客户端Ajax引擎,再由Ajax引擎来决定将这些数据插入到页面的指定位置。

所以Ajax最大的特点就是无刷新的更新页面,减轻了服务器的负担。

 

 

 2.Ajax技术

Ajax是JavaScript、XML、CSS、DOM等多种已有技术的组合。

 

2.1XMLHttpRequest

Ajax最核心的技术就是XMLHttpRequest,它是一个具有应用程序接口的JavaScript对象,通过它,可以只同服务器进行数据层面的交换,而不用每次都刷新页面。

 

 XMLHttpRequest对象的常用方法及常用属性如下:

 

 

2.2JavaScript

在Web页面中添加动态脚本代码的解释性程序语言。

 

2.3DOM

Document Object Model(文档对象模型),是表示文档和访问、操作构成文档的各种元素(如HTML标记和文本串)的应用程序接口。在Ajax应用中,通过JavaScript操作DOM,可以达到在不刷新页面的情况下实时修改用户界面的目的。

 

2.4XML

Extensible Markup Language(可扩展的标记语言),提供了用于描述结构化数据的格式。

 

2.5CSS

层叠样式表,用于页面布局,通过改变文档对象的CSS属性控制页面的外观和行为。

 

 

3.传统Ajax的工作流程

 

 3.1发送请求

1)初始化XMLHttpRequest对象

使用XMLHttpRequest之前需要进行初始化,初始化的方法如下:

 

if(window.XMLHttpRequest){
    http_request=new XMLHttpRequest(); //非IE浏览器
}
else if(window.ActiveObject){    //IE浏览器
    try{
        http_request=new ActiveObject("Msxml2.XMLHTTP");
    }
    catch(e){
        try{
            http_request=new ActiveObject("Microsoft.XMLHTTP");
        }
        catch(e){}
    }
}

 

2)为XMLHttpRequest对象指定一个回调函数,用于对返回结果进行处理。

http_request.onreadystatechange=getResult; //调用回调函数

如果要指定传递的参数,可以应用以下方法:

http_request.onreadystatechange=function(){getResult(param)};

3)创建一个与服务器的连接,在创建时,需要指定发送请求的方式,以及设置是否采用异步方式发送请求

http_request.open("GET", url, true);
// http_request.open("POST", url,true);

4)向服务器发送请求。利用send()方法可以实现向服务器发送请求,该方法需要传递一个参数,如果发送的是GET请求,可以将参数设置为null;如果发送的是POST请求,该方法需要通过该参数指定要发送的请求参数。

发送GET请求:

http_request.send(null);

发送POST请求:

http_request.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
var param="user="+......;//组合参数
http_request.send(param);

3.2处理服务器响应

在指定的回调函数中,首先需要判断服务器的请求状态,保证请求已完成,然后再根据服务器的HTTP状态码,判断服务器对请求的响应是否成功,如果成功,则获取服务器的响应反馈给客户端。XMLHttpRequest对象提供了两个用来访问服务器响应的属性:一个是responseText属性,返回字符串响应;另一个是responseXML属性,返回XML响应。

1)处理字符串响应

function getResult(){
    if(http_request.readyState==4){           //判断请求状态
        if(http_request.status==200){         //请求成功,开始处理相应
            alert(http_request.responseText);  //弹出提示对话框显示响应结果
        }else{
            alert("错误");
        }
        
    }
}

2)处理XML响应

var xmldoc=http_request.responseXML;

解析xmldoc