xmlhttp异步操作之代码说明

Admin | 2008-7-6 18:12:17 | TrackRecord: 1518 Times | Tag标签:asp.net 打印本页

您当前所处的位置是:〖首页〗→【文章页】 本站共有16个图文教程栏目,请用心拜读!

本站提供经典的Excel公式函数实例,Word排版技巧,PPT教程;同时更兼有Flash,PowerPoint,数据库等技术文章。

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

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

   function DoSomething()
{
MyPage.Method1.Do(val1,val2,CallBack);
}
function CallBack(res)
{
//res.value;
}

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

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

        ①请求没有发出(在调用 open() 之前)。

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

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

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

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

        在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);



上一篇:十一个常规用法就是提高NET程序性能    下一篇:XML与DataSet(DataTable)数据互转源

会员评论列表:
针对本篇文章或本站,请您发表个人的建议或批评!
FreeBoxPc

谷歌搜索 百度搜索 本站仅与内容具备一定的实用价值的原创网站交换友情链接,力争为大众做出更优质的服务!
All Rights Reserved版权所有 本站备案信息:滇ICP备11001339号-2 站长联系方式 Email:dzwebs@126.com