GVKun编程网logo

AJAX客户端说明,XMLHttpRequest对象(ajax和xmlhttp)

24

对于AJAX客户端说明,XMLHttpRequest对象感兴趣的读者,本文将提供您所需要的所有信息,我们将详细讲解ajax和xmlhttp,并且为您提供关于6.2:Ajax的XMLHttpReques

对于AJAX客户端说明,XMLHttpRequest对象感兴趣的读者,本文将提供您所需要的所有信息,我们将详细讲解ajax和xmlhttp,并且为您提供关于6.2:Ajax的XMLHttpRequest对象、Ajax - XMLHttpRequest对象详解、AJAX / XHR :XMLHttpRequest对象、AJAX XMLHttpRequest对象的宝贵知识。

本文目录一览:

AJAX客户端说明,XMLHttpRequest对象(ajax和xmlhttp)

AJAX客户端说明,XMLHttpRequest对象(ajax和xmlhttp)

在CommunityServer中运用了自己的AJAX机制,没有借助其他的辅助控件。其中客户的XMLHttpRequest对象的封装,就足以让人大饱眼福,在一般的浏览器其都能够运行AJAX。下面我们来学习学习这个咚咚,希望能给更多的人带来帮助。

 首先当然是要了解一下浏览器中的XMLHttp对象了:

 XMLHTTP方法: 
         备注:客户机可以使用XMLHTTP对象发送任意的HTTP请求,接受HTTP应答,还可以对应答的XML文档进行解析。 

         Open方法:初始化一个Msxml2.XMLHTTP请求,指定HTTP请求方式、URL以及鉴定信息。

        语法:
         Open( bstrMethod, bstrUrl, varAsync, bstrUser, bstrPassword ) 

        参数介绍:

        bstrMethod: 数据传送方式,即GET或POST。 
         bstrUrl: 服务网页的URL。 
         varAsync: 是否同步执行。缺省为True,即同步执行,但只能在DOM中实施同步执行。用中一般将其置为False,即异步执行。 
         bstrUser: 用户名,可省略。 
         bstrPassword:用户口令,可省略。 

        Send方法:发送HTTP请求到服务器,返回应答。 

        语法: 
        oXMLHttpRequest.send(varBody) 

       说明:此方法是否同步取决于Open方法的varAsync参数。如果设为True则为同步,调用立刻返回,如果设为False调用直到整个应答被接收了才返回。 

        setRequestHeader( bstrHeader, bstrvalue )

        bstrHeader:HTTP 头(header) 
        bstrvalue: HTTP 头(header)的值 

       如果Open方法定义为POST,可以定义表单方式上传: 
       xmlhttp.setRequestHeader( "Content-Type", "application/x-www-form-urlencoded") 

XMLHTTP属性: 

 onreadystatechange:在同步执行方式下获得返回结果的事件句柄。只能在DOM中调用。 
 responseBody: 结果返回为无符号整数数组。 
 responseStream: 结果返回为IStream流。 
 responseText : 结果返回为字符串。 
 responseXML: 结果返回为XML格式数据。

 运用这个原理也可以做网络小偷程序,网络爬虫应该就是应用这个东西来完成的吧,不过我没有做过,可能在不久的将来会制作个来玩玩,这里我们最主要的是看看CS中是如何封装他的:

   1//Ajax Start
 2/**////<summary>
 3///创建回调对象,如果存在window.XMLHttpRequest()对象,则返回此对象,如果是IE则搜索Msxml2.XMLHTTP各个版本及Microsoft.XMLHTTP并创建对象返回。
 4///</summary>
 5function Ajax_GetXMLHttpRequest() {
 6    if (window.XMLHttpRequest) {
 7        return new XMLHttpRequest();
 8    } else {
 9        if (window.Ajax_XMLHttpRequestProgID) {
            return new ActiveXObject(window.Ajax_XMLHttpRequestProgID);
        } else {
            var progIDs = ["Msxml2.XMLHTTP.5.0", "Msxml2.XMLHTTP.4.0", "MSXML2.XMLHTTP.3.0", "MSXML2.XMLHTTP", "Microsoft.XMLHTTP"];
            for (var i = 0; i < progIDs.length; ++i) {
                var progID = progIDs[i];
                try {
                    var x = new ActiveXObject(progID);
                    window.Ajax_XMLHttpRequestProgID = progID;
                    return x;
                } catch (e) {
                }
            }
        }
    }
    return null;
}
/**////<summary>
///Ajax回调。
///</summary>
///<param name="type">调用服务端函数所在的类包括命名空间(如:NExplus.Controls.SiteHeader)。</param>
///<param name="id">客户端所对应的标记的ID(如:<div id="ID"></div>)。</param>
///<param name="method">服务端(方法)函数名称(被AjaxMethod标记)。</param>
///<param name="args">传到服务器的字符串。</param>
///<param name="clientCallBack">同步或异步回调。</param>
///<param name="debugRequestText">调试/请求字符串。</param>
///<param name="debugResponseText">调试/输出字符串。</param>
///<param name="debugErrors">调试的错误信息。</param>
///<param name="includeControlValuesWithCallBack">是否和控件及其值一起回调。</param>
///<param name="url">Url地址。</param>
function Ajax_CallBack(type, id, method, args, clientCallBack, debugRequestText, debugResponseText, debugErrors, includeControlValuesWithCallBack, url) {

    if (!url)
    {
        url = window.location.href;
        url = url.replace(/\#.*$/, '''');//去除URL中标签部分,即"#"之后的字符串。
        //加入参数Ajax_CallBack并设为true,说明是AJAX回调。
        if (url.indexOf(''?'') > -1)
            url += "&Ajax_CallBack=true";
        else
        {
            if (url.substr(url.length - 1, 1) == "/")
                url += "default.aspx";

            url += "?Ajax_CallBack=true";
        }
    }

    var x = Ajax_GetXMLHttpRequest();//取得XMLHttpRequest对象。
    var result = null;
    if (!x) {
        result = { "value":null, "error": "NOXMLHTTP"};
        if (debugErrors) {
            alert("error: " + result.error);
        }
        if (clientCallBack) {
            clientCallBack(result);
        }
        return result;
    }

    x.open("POST", url, clientCallBack ? true : false);//以Post方式打开对象,这样在服务端就可以用Request.Form获取参数。
    x.setRequestHeader("Content-Type", "application/x-www-form-urlencoded; charset=utf-8");
    if (clientCallBack) {
        //如果同步,判断状态,输出错误消息。
        x.onreadystatechange = function() {
            var result = null;

            if (x.readyState != 4) {
                return;
            }

            if (debugResponseText) {
                alert(x.responseText);
            }

            try
            {
                var result = eval("(" + x.responseText + ")");
                if (debugErrors && result.error) {
                    alert("error: " + result.error);
                }
            }
            catch (err)
            {
                if (window.confirm(''The following error occured while processing an AJAX request: '' + err.message + ''\n\nWould you like to see the response?''))
                {
                    var w = window.open();
                    w.document.open(''text/plain'');
                    w.document.write(x.responseText);
                   w.document.close();
               }

               result = new Object();
               result.error = ''An AJAX error occured.  The response is invalid.'';
           }

           clientCallBack(result);            
       }
   }
   var encodedData = "Ajax_CallBackType=" + type;
   if (id) {
       encodedData += "&Ajax_CallBackID=" + id.split("$").join(":");
   }
   encodedData += "&Ajax_CallBackMethod=" + method;
   if (args) {
       for (var i in args) {
           encodedData += "&Ajax_CallBackArgument" + i + "=" + encodeURIComponent(args[i]);
       }
   }
   //如果加入控件,则加入控件数据。
   if (includeControlValuesWithCallBack && document.forms.length > 0) {
       var form = document.forms[0];
       for (var i = 0; i < form.length; ++i) {
           var element = form.elements[i];
           if (element.name) {
               var elementValue = null;
               if (element.nodeName == "INPUT") {
                   var inputType = element.getAttribute("TYPE").toUpperCase();
                   if (inputType == "TEXT" || inputType == "PASSWORD" || inputType == "HIDDEN") {
                       elementValue = element.value;
                   } else if (inputType == "CHECKBOX" || inputType == "RADIO") {
                       if (element.checked) {
                           elementValue = element.value;
                       }
                   }
               } else if (element.nodeName == "SELECT") {
                   elementValue = element.value;
               } else if (element.nodeName == "TEXTAREA") {
                   elementValue = element.value;
               }
               if (elementValue) {
                   encodedData += "&" + element.name + "=" + encodeURIComponent(elementValue);
               }
           }
       }
   }
   //如果是调试,则弹出发送的数据。
   if (debugRequestText) {
       alert(encodedData);
   }
   x.send(encodedData);//向服务器发送数据。
   if (!clientCallBack) {
       if (debugResponseText) {
           alert(x.responseText);
       }
       result = eval("(" + x.responseText + ")");
       if (debugErrors && result.error) {
           alert("error: " + result.error);
       }
   }
   delete x;
   return result;
}

//Ajax End
 其他的不用多说明了,看注释应该就差不多了,如果有不对的地方请批评指教,谢谢!
您可能感兴趣的文章:
  • jQuery 利用$.ajax 时获取原生XMLHttpRequest 对象的方法
  • AJAX XMLHttpRequest对象详解
  • 解析ajax核心XMLHTTPRequest对象的创建与浏览器的兼容问题
  • 如何用ajax来创建一个XMLHttpRequest对象
  • jquery ajax学习笔记2 使用XMLHttpRequest对象的responseXML
  • AJAX中同时发送多个请求XMLHttpRequest对象处理方法
  • AJax 学习笔记一(XMLHTTPRequest对象)
  • ajax 入门基础之 XMLHttpRequest对象总结
  • AJAX XMLHttpRequest对象创建使用详解

6.2:Ajax的XMLHttpRequest对象

6.2:Ajax的XMLHttpRequest对象

占地

Ajax - XMLHttpRequest对象详解

Ajax - XMLHttpRequest对象详解

XMLHttpRequest 对象是 Ajax 技术的核心。在 Internet Explorer 5 中, 对象以 ActiveX 对象引入,被称之为 XMLHTTP ,它是一种支持异步请求的技术。后来 Mozilla netscape Safari Firefox 和其他浏览器也提供了 类,虽然这些浏览器都提供了 类,但它们创建 类的方法并不相同。 使我们可以使用 JavaScript 向服务器提出请求并处理响应,而不阻塞用户的其他操作。

不刷新页面就和服务器进行交互是Ajax最大的特点。这个重要的特点主要归功于XMLHttpRequest对象。使用XMLHttpRequest对象使得网页应用程序像windows应用程序一样,能够及时响应用户与服务器之间的交互,不必进行页面刷新或者跳转,并且能够进行一系列的数据处理,这些功能可以使用户的等待时间缩短,同时也减轻了服务器端的负载。

目前XMLHttpRequest对象已经得到了大部分浏览器的支持,因此使用Ajax技术开发Web应用程序的时候一般情况下不会出现问题。不过,当开发人员确定使用Ajax技术来开发时,仍然需要考虑用户会使用什么样的浏览器来对网站进行访问,虽然不支持XMLHttpRequest对象的浏览器占少数。

在使用XMLHttpRequest对象向服务器发送请求和处理响应之前,必修先用JavaScript创建一个XMLHttpRequest对象,然后通过这个对象来和服务器建立请求并接收服务器返回的数据。由于XMLHttpRequest不是一个W3C标准,所以可以采用多种方法使用JavaScript来创建XMLHttpRequest的实例。Internet Explorer把XMLHttpRequest实现为一个ActiveX对象,其他浏览器(如Firefox、Safari和Opera等)把它实现为一个本地JavaScript对象。由于存在这些差别,JavaScript代码中必须包含有关的逻辑,从而使用ActiveX技术或者使用本地JavaScript对象技术来创建XMLHttpRequest的一个实例。

正因为在不同的浏览器中,XMLHttpRequest对象的创建方式不同,因此在程序中创建XMLHttpRequest对象之前需要对浏览器进行判断。使用详细编写代码方式来区别浏览器类型的方式不仅代码量大,而且很不方便也不灵活。在这里我们可以换一种思路来解决,只需要检查浏览器是否提供对ActiveX对象的支持即可。如果浏览器支持ActiveX对象,就可以使用ActiveX来创建XMLHttpRequest对象。否则,就需要在程序中使用本地JavaScript对象技术来创建。下面的代码展示了在不同的浏览器中使用JavaScript代码来创建XMLHttpRequest对象的编程方法。

#001 function createXMLHttpRequest()

#002 {

#003var xmlreq = false;

#004if (window.ActiveXObject)

#005{

#006xmlreq = new ActiveXObject("Microsoft.XMLHTTP");

#007}

#008else if (window.XMLHttpRequest)

#009{

#010xmlreq = new XMLHttpRequest();

#011}

#012return xmlreq;

#013 }

我们从上面代码中看出,创建XMLHttpRequest对象的过程比较简单。首先在createXMLHttpRequest()方法中创建了一个变量xmlreq来保存对这个对象的引用,并将其默认值设置为false。然后在这个方法中通过简单的判断,确定究竟使用什么方法来创建对象。由于用户使用的浏览器类型不同,代码window.ActiveXObject可能返回一个对象,也可能返回null。If条件语句根据返回的结果来判断浏览器是否能支持ActiveX控件,相应地得知浏览器是IE还是其他浏览器类型。如果判定用户使用的是IE浏览器,则通过实例化ActiveXObject的一个实例的方法来创建XMLHttpRequest对象。使用这种方法时,参数字符串指明要创建何种类型的ActiveX对象。在本例子中,参数是Microsoft.XMLHTTP,这说明需要创建的是XMLHttpRequest的一个实例。

如果window.ActiveXObject返回null,表示用户使用的浏览器不支持ActiveX对象,那么程序会执行else语句所指定的操作。首先判断浏览器是否把XMLHttpRequest实现为本地JavaScript对象。如果存在window.XMLHttpRequest,那么就创建XMLHttpRequest对象。最后将这个xmlreq变量返回,完成了XMLHttpRequest对象的创建过程。

由于JavaScript具有动态类型的特性,而且XMLHttpRequest对象在不同浏览器上的实现是兼容的,所有可以用同样的方式访问XMLHttpRequest实例的属性和方法,而不论这个实例创建的方法是什么。这就大大简化了开发过程,而且在JavaScript中也不必编写特定于浏览器的逻辑。

XMLHttpRequest对象的属性

XMLHttpRequest对象提供了许多属性,处理XMLHttpRequest时需要频繁用到这些属性,如下表所示:

属性

描述

onreadystatechange

每个状态改变时都会触发这个事件处理程序,通常会调用一个JavaScript函数

readyState

请求的状态

responseText

服务器的响应,表示为一个串

responseXML

服务器的响应,表示为XML,这个对象可以解析为一个DOM对象

status

服务器的HTTP状态

statusText

HTTP状态的对应文本

下面我们来看看这些属性和事件的详细说明。

1. readyState属性

当XMLHttpRequest对象吧一个HTTP请求发送到服务器时将经历若干种状态。一直等待直到请求被处理,然后,它才接收一个响应。这样以来,脚本才正确响应各种状态,XMLHttpRequest对象暴露一个描述对象的当前状态的readyState属性,如下表所示:

readyState取值

描述

0

描述一种“未初始化”状态。此时,已经创建了一个XMLHttpRequest对象,但是还没有初始化。

1

描述一种“发送”状态。此时,代码已经调用了XMLHttpRequest open()方法并且XMLHttpRequest已经准备好把一个请求发送到服务器。

2

描述一种“发送”状态。此时,已经通过send()方法把一个请求发送到服务器端,但是还没有收到一个响应。

3

描述一种“正在接收”状态。此时,已经接收到HTTP响应头部信息,但是消息体部分还没有完全接收结束。

4

描述一种“已加载”状态。此时,响应已经被完全接收。

2. onreadystatechange属性

无论readyState值何时发生改变,XMLHttpRequest对象都会激发一个readystatechange事件。其中,onreadystatechange属性接收一个EventListener值,向该方法指示无论readyState值何时发生改变,该对象都将激活。

3. responseText属性

这个responseText属性包含客户端接收到的HTTP响应的文本内容。当readyState值为0、1或2时,responseText包含一个空字符串。当readyState值为3(正在接收)时,响应中包含客户端还未完成的响应信息。当readyState为4(已加载)时,该responseText包含完整的响应信息。

4. responseXML属性

此属性用于当接收到完整的HTTP响应时(readyState为4)描述XML响应;此时,Content-Type头部指定MIME(媒体)类型为text/xml,application/xml或以+xml结尾。如果Content-Type头部并不包含这些媒体类型之一,那么responseXML的值为null。无论何时,只要readyState值不为4,那么该responseXML的值也为null。

其实,这个responseXML属性值是一个文档接口类型的对象,用来描述被分析的文档。如果文档不能被分析(例如,如果文档不是良构的或不支持文档相应的字符编码),那么responseXML的值将为null。

5. status属性

这个属性描述了HTTP状态代码,而且其类型为short。而且,仅当readyState值为3(正在接收中)或4(已加载)时,这个status属性才可用。当readyState的值小于3时试图存取status的值将引发一个异常。例如:status等于200表示成功,404表示未找到资源。

6. statusText属性

这个属性描述了HTTP状态代码文本,并且仅当readyState值为3或4才可用。当readyState为其它值时试图存取statusText属性将引发一个异常。

XMLHttpRequest对象的方法

下表显示了XMLHttpRequest对象的一些常用的方法,其中描述部分介绍了这些方法的作用和意义。

方法

描述

abort()

停止当前请求

getAllResponseHeaders()

把HTTP请求的所有相应首部作为键/值对返回。

getResponseHeader("header")

返回指定首部的串值。

open("method","url")

建立对服务器的调用。method参数可以是GET、POST或PUT等;url参数可以是相对URL或绝对URL。这个方法还包括3个可选参数。

send(content)

向服务器发送请求。

setRequestHeader("header","value")

把指定首部设置为所提供的值,在设置任何首部之前必须先调用open()方法。

下面我们来更详细的看看这些方法的使用。

1. abort()方法

可以使用这个abort()方法来暂停与一个XMLHttpRequest对象相联系的HTTP请求,从而把该对象复位到未初始化状态。

2. open()方法

此方法用来和服务器之间建立连接。其完整的方法参数是open(string method,string uri,boolean asynch,string username,string password),其中前两个参数是必要的,后面三个为可选参数。

method参数是必须提供的,用于指定用来发送请求的HTTP方法(GET,POST,PUT,DELETE或HEAD)。为了把数据发送到服务器,应该使用POST方法;为了从服务器端检索数据,应该使用GET方法。另外,uri参数用于指定XMLHttpRequest对象把请求发送到的服务器相应的URI。借助于window.document.baseURI属性,该uri被解析为一个绝对的URI。换句话说,如果使用相对的URI,它将使用与浏览器解析相对的URI一样的方式被解析。Asynch参数指定是否请求是异步的,缺省值为true。为了发送一个同步请求,需要把这个参数设置为false。但Ajax技术的最大优点是调用,因此如果这个参数设置为false,则将失去使用XMLHttpRequest对象的意义。对于要求认证的服务器,可以提供可选的用户名和口令参数。在调用open()方法后,XMLHttpRequest对象把它的readyState属性设置为1(打开)并且把responseText、responseXML、status和statusText属性复位到它们的初始值。另外,它还复位请求头部。注意,如果调用open()方法并且此时readyState为4,则XMLHttpRequest对象将复位这些值。

3. send()方法

在通过调用open()方法准备好一个请求之后,需要把该请求发送到服务器。仅当readyState值为1时,才可以调用send()方法。否则的话,XMLHttpRequest对象将引发一个异常。该请求被使用提供给open()方法的参数发送到服务器。当asynch参数为true时,send()方法立即返回,从而允许其它客户端脚本处理继续。在调用send()方法后,XMLHttpRequest对象把readyState的值设置为2(发送)。当服务器响应时,在接收消息体之前,如果存在任何消息体的话,XMLHttpRequest对象将把readyState设置为3(正在接收中)。当请求完成加载时,它把readyState设置为4(已加载)。对于一个HEAD类型的请求,它将在把readyState值设置为3后再立即把它设置为4。

send()方法使用一个可选的参数,该参数可以包含可变类型的数据。典型地,使用它并通过POST方法把数据发送到服务器。另外,可以显式地使用null参数调用send()方法,这与不用参数调用它一样。对于大多数其它的数据类型,在调用send()方法之前,应该使用setRequestHeader()方法(见后面的解释)先设置Content-Type头部。如果在send(content)方法中的content参数的类型为string,那么,数据将被编码为UTF-8。如果数据是Document类型,那么将使用由data.xmlEncoding指定的编码串行化该数据。

注意,由于调用这个方法后就把请求发出去了,所以对于XMLHttpRequest对象的设置需要在调用这个方法之前来完成。另外,对于send()方法中的那个参数,虽然是可选的,但是最好在不需要发送数据的时候也不能省略这个参数,应该将其设置成null,否则将会在Firefox中有错误。

4. setRequestHeader("header","value")方法

该方法用来设置请求的头部信息。当readyState值为1时,可以在调用open()方法后调用这个方法。否则,将得到一个异常。

5. getResponseHeader("header")方法

该方法用于检索响应的头部值。仅当readyState值是3或4(换句话说,在响应头部可用以后)时,才可以调用这个方法;否则,该方法返回一个空字符串。

6. getAllResponseHeaders()方法

该方法以一个字符串形式返回所有的响应头部(每一个头部占单独的一行)。如果readyState的值不是3或4,则该方法返回null。

AJAX / XHR :XMLHttpRequest对象

AJAX / XHR :XMLHttpRequest对象

Ajax在我之前的博客中,多多少少已经提起一点了,今天介绍下Ajax中XMLHttpRequest对象。



Ajax 通俗地讲可以实现网页的局部刷新,减轻服务的负荷量,给用户更好的体验度。



Ajax的工作原理:Ajax可以通过回调函数的使用,在获取服务器的数据后,实现部分加载的功能。如图:







XHR(xmlhttprequest)是Ajax的核心对象。其实就是Ajax实例化的执行者,很多方法和属性需要由它来执行。



那么XHR具体实如何来实现局部刷新的呢?分五步:



1.建立XHR对象。



2.注册回调函数。



3.使用open()方法设置和服务交互的基本信息。



4.使用send()方法设置发送的数据,开始和服务器交互。



5.在回调函数中判断交互状态readystate,更新页面。


其中需要注意的几点:



1.建立XHR对象很简单variable = new XMLHttpRequest(),但是需要兼容不同的浏览器:


  var xmlhttp;
if(window.XMLHttpRequest)
  {
// 兼容 IE7+,Firefox,Chrome,Opera,Safari
  xmlhttp=new XMLHttpRequest();
  }
else
  {
// 兼容 IE6,IE5
  xmlhttp=newActiveXObject("Microsoft.XMLHTTP");
  }

2.Open 方法的参数设置:



Open(method,URL,async):



Method:表示请求服务的类型,分为get 和 post 两种。



URL:表示要存储文件在服务器上的位置。如果是采用数据库则要确定到数据库的【.mdb】的位置。如果是在项


目中自己建立的servlet容器或者xml存储文件,则确定要项目中对应的位置即可。


3.XMLHttpRequest对象的属性:



responseText:表示返回字符串形式的数据;



responseXML:表示返回xml形式的数据;



onreadystatechange:存储函数,当有readystate属性改变时,就会调用该函数;



readystate:



0 :请求未初始化;



1 :服务器已经建立连接;



2 :请求已经接收;



3 :请求处理中;



4 :请求已经完成,且响应就绪;


Status:



200 :“OK”



404 :未找到页面。



当readystate 等于4且状态为200 时,表示向服务器提交的请求已经反馈回来且准备就绪。


总结:



Ajax 是一项用于创建web 交互的技术,它是写在JS 文件中的,通过对HTML中元素注册特殊事件,在JS 中和数



据库进行交互,同时使用回调函数完成局部刷新(其实就是在HTML中先写一个容器div或其他,然后通过Ajax的五步



骤,将返回的数据装入到d容器中,因为本来容器就是存在的,所以看上去好像并不突兀,也没有整个页面提交)。



目前对Ajax的学习还比较浅,有不对的请多指教。

AJAX XMLHttpRequest对象

AJAX XMLHttpRequest对象

XMLHttpRequest对象:

XMLHttpRequest对象是AJAX 的核心,
XMLHttpRequest 对象提供了对 HTTP 协议的完全的访问,包括做出 POST 和 HEAD 请求以及普通的 GET 请求的能力。XMLHttpRequest 可以同步或异步地返回 Web 服务器的响应,并且能够以文本或者一个 DOM 文档的形式返回内容。

属性和方法:

属性:
readyState
HTTP 请求的状态.当一个 XMLHttpRequest 初次创建时,这个属性的值从 0 开始,直到接收到完整的 HTTP 响应,这个值增加到 4。

每一次状态改变都会触发onreadystatechange事件。

responseText
目前为止为服务器接收到的响应体(不包括头部),或者如果还没有接收到数据的话,就是空字符串。
如果 readyState 小于 3,这个属性就是一个空字符串。当 readyState 为 3,这个属性返回目前已经接收的响应部分。如果 readyState 为 4,这个属性保存了完整的响应体。
如果响应包含了为响应体指定字符编码的头部,就使用该编码。否则,假定使用 Unicode UTF-8。

responseXML
对请求的响应,解析为 XML 并作为 Document 对象返回。

status
由服务器返回的 HTTP 状态代码,如 200 表示成功,而 404 表示 “Not Found” 错误。当 readyState 小于 3 的时候读取这一属性会导致一个异常。

statusText
这个属性用名称而不是数字指定了请求的 HTTP 的状态代码。也就是说,当状态为 200 的时候它是 “OK”,当状态为 404 的时候它是 “Not Found”。和 status 属性一样,当 readyState 小于 3 的时候读取这一属性会导致一个异常。

方法:
abort()
取消当前响应,关闭连接并且结束任何未决的网络活动。
这个方法把 XMLHttpRequest 对象重置为 readyState 为 0 的状态,并且取消所有未决的网络活动。例如,如果请求用了太长时间,而且响应不再必要的时候,可以调用这个方法

open()
初始化 HTTP 请求参数,例如 URL 和 HTTP 方法,但是并不发送请求。

open(method,url,async,username,password)

method 参数是用于请求的 HTTP 方式。值包括 GET、POST 和 HEAD。
url 参数是请求的主体,服务器端地址。
async 参数指示请求使用应该异步地执行。如果这个参数是 false,请求是同步的,后续对 send() 的调用将阻塞,直到响应完全接收。如果这个参数是 true 或省略,请求是异步的,不用等待返回结果,可以接着执行send()。

send()
发送 HTTP 请求,使用传递给 open() 方法的参数,以及传递给该方法的可选请求体。

setRequestHeader()
向一个打开但未发送的请求设置或添加一个 HTTP 请求。
setRequestHeader() 方法指定了一个 HTTP 请求的头部,它应该包含在通过后续 send() 调用而发布的请求中。这个方法只有当 readyState 为 1 的时候才能调用,例如,在调用了 open() 之后,但在调用 send() 之前。

setRequestHeader(name,value)

getAllResponseHeaders()
把 HTTP 响应头部作为未解析的字符串返回。
如果 readyState 小于 3,这个方法返回 null。否则,它返回服务器发送的所有 HTTP 响应的头部。头部作为单个的字符串返回,一行一个头部。每行用换行符 “\r\n” 隔开。

getResponseHeader()
返回指定的 HTTP 响应头部的值。其参数是要返回的 HTTP 响应头部的名称。
该方法的返回值是指定的 HTTP 响应头部的值,如果没有接收到这个头部或者 readyState 小于 3 则为空字符串。如果接收到多个有指定名称的头部,这个头部的值被连接起来并返回,使用逗号和空格分隔开各个头部的值。

五步使用法:
(1).建立XMLHttpRequest对象

if(window.XMLHttpRequest){
         //IE7+、Firefox、Chrome、Safari 以及 Opera
            var xmlhttp=new XMLHttpRequest();
            if (xmlhttp.overrideMimeType){
                xmlhttp.overridemineType("text/xml");
               }
           }
    else if(window.ActiveXObject){
                  //IE5 和 IE6
                  try{
                  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");      
              }catch(e){  

              }
             } 
      if(xmlhttp==undefined || xmlhttp==null){
                 alert("当前浏览器不支持创建XMLhttp对象 ");
                 return;           
             }

(2).注册回掉函数

 xmlhttp.onreadystatechange=callback;

(3)使用open方法设置和服务器端交互的信息

xmlhttp.open("GET","AJAX?name="+userName,true); //交互参数

(4)设置发送的数据,开始和服务器端交互

xmlhttp.send(null);

(5)在回调函数中判断交互是否结束,响应是否正确,并根据需要获取服务器端返回的数据,更新页面。

document.getElementById("myDiv").innerHTML=xmlhttp.responseText;

总结:
ajax 的核心是XMLHttpRequest对象,该对象使得ajax 可以同步或者异步地请求服务器,动态刷新页面。

关于AJAX客户端说明,XMLHttpRequest对象ajax和xmlhttp的介绍已经告一段落,感谢您的耐心阅读,如果想了解更多关于6.2:Ajax的XMLHttpRequest对象、Ajax - XMLHttpRequest对象详解、AJAX / XHR :XMLHttpRequest对象、AJAX XMLHttpRequest对象的相关信息,请在本站寻找。

本文标签: