| [ //实际发送一个空请求 req.send(null); ] |
| 属性 | 描述 |
| onreadystatechange | 每当状态改变时激发的事件的事件处理器。其中,readyState对象状态整数含义如下:0=uninitialized1=loading2=loaded3=interactive4=complete |
| responseText | 经服务器处理后返回的数据的字符串版本 |
| responseXML | 经服务器处理后返回的DOM兼容的数据文档对象 |
| status | 由服务器返回的数字代码,例如404代表"Not Found",200代表"OK" |
| statusText | 伴随着状态代码的字符串信息 |
| //这是事件处理器机制;在本例中,"RequestProcessor"即是事件处理器。 req.onreadystatechange=RequestProcessor; |
| function RequestProcessor() { //如果readyState处理"Ready"状态 if(req.readyState == 4) { //返回的状态代码200意味着一切顺利 if(req.status == 200) { //如果responseText不空 //req.responseText实际上是一个由AJAXServer.aspx的"Response.Write("" + sbXML.ToString() + "");"方法编写的字符串 if(req.responseText != "") { populateList(req.responseXML); } else { clearSelect(publishedBooks); } } } return true; } |
| var req = new ActiveXObject("Microsoft.XMLHTTP"); |
警告
请求目的的url必须与客户端脚本处于同一个域中。原因是,XMLHttpRequest对象采用与客户端脚本一致的封装技术。在大多数支持这种功能的浏览器上,拥有存取XMLHttpRequest对象的脚本的页面都需要使用http:协议检索。这意味着,你无法在一个本地硬盘上(file:协议)进行页面测试。
三、 实际问题
在AJAX中,如果网络或远程服务器出现中断,会发生什么呢?实际上,存在两个主要问题;默认地,它们并没有在XMLHttpRequest对象中得到解决。这两个主要问题是:
1.处理延迟:如果网络或远程服务器耗费较多时间,那么这个问题如何与你的AJAX应用程序相联系呢?
2.响应顺序:潜在地,网络(或服务器)会不断变化。这意味着,响应可能不会以与请求相同的顺序返回。
为了处理上面这两个问题,程序员必须编写代码来解决这个问题。对于第一个问题,一种可能的方案如下所示:
| function callInProgress(xmlhttp) { switch ( xmlhttp.readyState ) { case 1,2,3: return true; break; //Case 4和0 default: return false; break; } } |
现在,在调用send()前,我可以先检查一下是否该对象正处于忙态: