xmlhttp是如何完成异步操作的

ZDNet软件频道 时间:2008-07-09 作者: | 中国IT实验室 我要评论()
本文关键词:异步 HTTP XML 软件
在ajax中最常用的就是状态标志4,回调函数中发现状态标志为4的时候,就可以做处理请求数据的操作了。

ajax第一个字母就是Asynchronous-异步,那么到底XMLHTTP为何能支持异步操作呢?

  大家在使用ajaxpro的时候,经常这么调用服务器端方法

   function DoSomething()

function CallBack(res)

 


  这样在调用DoSomething方法的时候,会很快返回,用户可以继续操作界面,直到回调函数得到通知运行,再处理本次请求的结果。这就是一次异步操作。

  那是通过什么样的机制来完成对CallBack函数的通知的呢,XMLHTTPRequest对象支持一种onreadystatechange的委托,请求j状态的更改会触发这个委托。 HTTP 就绪状态表示请求的状态或情形。它用于确定该请求是否已经开始、是否得到了响应或者请求/响应模型是否已经完成。它还可以帮助确定读取服务器提供的响应文本或数据是否安全。在 Ajax 应用程序中需要了解五种就绪状态:
 0:请求没有发出(在调用 open() 之前)。

 1:请求已经建立但还没有发出(调用 send() 之前)。

 2:请求已经发出正在处理之中(这里通常可以从响应得到内容头部)。

 3:请求已经处理,响应中通常有部分数据可用,但是服务器还没有完成响应。

 4:响应已完成,可以访问服务器响应并使用它。

  在ajax中最常用的就是状态标志4,回调函数中发现状态标志为4的时候,就可以做处理请求数据的操作了。
  比如创建XMLHTTPRequest的代码如下:

   function CreateXMLHTTPRequest(){
// Initialize Mozilla XMLHTTPRequest object
   if (window.XMLHTTPRequest){
XMLHTTP = new XMLHTTPRequest();
}
// Initialize for IE/Windows ActiveX version
   else if (window.ActiveXObject) {
try{
XMLHTTP = new ActiveXObject("MsXML2.XMLHTTP.3.0");
}
catch (e){
try{
XMLHTTP = new ActiveXObject("Microsoft.XMLHTTP");
}
catch (e){newsstring = "<div class='loading'>Loading rquest content fail, Please try it again latter</div>";}
}
}
}
 
  发出XMLHTTPrequest并支持回调函数的代码如下:

   XMLHTTP.onreadystatechange = function(){
// only if XMLHTTP shows "complete"
   if (XMLHTTP.readyState == 4){
// only HTTP 200 to process
      if (  XMLHTTP.status == 200){ CallBack();}}} XMLHTTP.open("GET", url, true);
XMLHTTP.setRequestHeader("If-Modified-Since","0");
XMLHTTP.send(null);
 

异步

HTTP

XML

软件


百度大联盟认证黄金会员Copyright© 1997- CNET Networks 版权所有。 ZDNet 是CNET Networks公司注册服务商标。
中华人民共和国电信与信息服务业务经营许可证编号:京ICP证010391号 京ICP备09041801号-159
京公网安备:1101082134