| 网管联盟 | 网管论坛 | 网管u家 | 网管博客 | 网管软件 | 网管求职 | 小游戏 | 网管搜索 | 网管原创 | 网管聚合 | 网管读摘 | 网管焦点 | 世界素材 | 会员投稿 | 会员中心 |
![]() |
| Windows Linux Cisco 网络技术 数据库 黑客攻防 DotNet Java PHP 认证 新闻资讯 服务器 存储资讯 网络设备 网管学堂 技术专题 焦点 网吧频道 |
ajax第一个字母就是Asynchronous-异步,那么到底xmlhttp为何能支持异步操作呢? 网管bitscn_com
大家在使用ajaxpro的时候,经常这么调用服务器端方法
网管网www_bitscn_com
| function DoSomething() { MyPage.Method1.Do(val1,val2,CallBack); } function CallBack(res) { //res.value; } |
这样在调用DoSomething方法的时候,会很快返回,用户可以继续操作界面,直到回调函数得到通知运行,再处理本次请求的结果。这就是一次异步操作。
那是通过什么样的机制来完成对CallBack函数的通知的呢,XmlHttpRequest对象支持一种onreadystatechange的委托,请求j状态的更改会触发这个委托。 HTTP 就绪状态表示请求的状态或情形。它用于确定该请求是否已经开始、是否得到了响应或者请求/响应模型是否已经完成。它还可以帮助确定读取服务器提供的响应文本或数据是否安全。在 Ajax 应用程序中需要了解五种就绪状态:
0:请求没有发出(在调用 open() 之前)。
网管联盟bitsCN_com
1:请求已经建立但还没有发出(调用 send() 之前)。
网管下载dl.bitscn.com
2:请求已经发出正在处理之中(这里通常可以从响应得到内容头部)。 中国网管论坛bbs.bitsCN.com
3:请求已经处理,响应中通常有部分数据可用,但是服务器还没有完成响应。 网管u家u.bitscn@com
4:响应已完成,可以访问服务器响应并使用它。
在ajax中最常用的就是状态标志4,回调函数中发现状态标志为4的时候,就可以做处理请求数据的操作了。
比如创建XmlHttpRequest的代码如下:
| function CreateXMLHttpRequest(){ // Initialize Mozilla XMLHttpRequest object if (window.XMLHttpRequest){ xmlHttp = new XMLHttpRequest(); } // Initialize for IE/Windows ActiveX version 网管bitscn_com else if (window.ActiveXObject) { try{ xmlHttp = new ActiveXObject("Msxml2.XMLHTTP.3.0"); } catch (e){ try{ 网管u家u.bitsCN.com xmlHttp = new ActiveXObject("Microsoft.XMLHTTP"); } catch (e){newsstring = "<div class='loading'>Loading rquest content fail, Please try it again latter</div>";} } } } |
| xmlHttp.onreadystatechange = function(){ // only if xmlHttp shows "complete" if (xmlHttp.readyState == 4){ // only http 200 to process 网管u家u.bitsCN.com if ( xmlHttp.status == 200){ CallBack();}}} xmlHttp.open("GET", url, true); xmlHttp.setRequestHeader("If-Modified-Since","0"); 中国网管联盟bitsCN.com xmlHttp.send(null); |
|
0
|
评论加载中…