AJAX中XMLHttpRequest.readyState总是为1

前端之家收集整理的这篇文章主要介绍了AJAX中XMLHttpRequest.readyState总是为1前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

AJAX中XMLHttpRequest.readyState总是为1

原创 2014年07月04日 15:21:52

写了一点ajax异步与后台通讯的代码

代码块很固定:

[javascript] view plain copy
  1. varXMLHttpReqScript;
  2. functioncreateXMLHttpReqScript(){
  3. if(window.XMLHttpRequest){//Mozilla浏览器
  4. XMLHttpReqScript=newXMLHttpRequest();
  5. }
  6. elseif(window.ActiveXObject){//IE浏览器
  7. try{
  8. newActiveXObject("Msxml2.XMLHTTP");
  9. }catch(e){
  10. try{
  11. "Microsoft.XMLHTTP");
  12. catch(e){}
  13. }
  14. functionsendRequestScript(){
  15. varworker=document.getElementById("workerID").value;
  16. varport=document.getElementById("portID").value;
  17. createXMLHttpReqScript();//(1)创建
  18. varurl="/SWTestSystem/GlobalServ?status=showResult&&worker="+worker+"&&port="+port;
  19. XMLHttpReqScript.open("GET",url,true);//(2)open,设置其请求的方式、地址、是否异步
  20. XMLHttpReqScript.onreadystatechange=processResponseScript;//(3)状态变化时调用方法
  21. XMLHttpReqScript.send(null);//(4)send请求
  22. functionprocessResponseScript(){
  23. if(XMLHttpReqScript.readyState==4){//请求已完成
  24. if(XMLHttpReqScript.status==200){
  25. DisplayScript();
  26. setTimeout("sendRequestScript()",1000);
  27. else{
  28. //window.alert("yourrequestpageiserror");
  29. functionDisplayScript(){
  30. varreceive=XMLHttpReqScript.responseText;//获取responseText(服务器返回的字符串)
  31. document.getElementById("script").value=receive;
  32. }

[javascript] view plain copy
  1. varXMLHttpReqScript;
  2. functioncreateXMLHttpReqScript(){
  3. //Mozilla浏览器
  4. newXMLHttpRequest();
  5. }
  6. //IE浏览器
  7. try{
  8. "Msxml2.XMLHTTP");
  9. catch(e){
  10. try{
  11. "Microsoft.XMLHTTP");
  12. catch(e){}
  13. }
  14. functionsendRequestScript(){
  15. "workerID").value;
  16. "portID").value;
  17. createXMLHttpReqScript();<spanstyle="white-space:pre"></span>//(1)创建
  18. "&&port="+port;
  19. true);<spanstyle=//(2)open,GET请求
  20. //(3)状态变化时调用方法
  21. null);<spanstyle=//(4)send
  22. functionprocessResponseScript(){
  23. if(XMLHttpReqScript.readyState==4){
  24. if(XMLHttpReqScript.status==200){
  25. DisplayScript();
  26. else{
  27. //window.alert("yourrequestpageiserror");
  28. functionDisplayScript(){
  29. varreceive=XMLHttpReqScript.responseText;
  30. "script").value=receive;
  31. }

但是之前页面总是不刷新,调试过后发现是因为XMLHttpReqScript.readyState 总是等于1 。

经查找,错误原因:

XMLHttpReqScript.onreadystatechange=processResponseScript();//写成这样了。

改成上面就好了

下面摘取网上某人(kokoBox@csdn)对readyState的分析

readyState有五种可能的值:
0(未初始化):(XMLHttpRequest)对象已经创建,但还没有调用open()方法
1(载入):已经调用open()方法,但尚未发送请求。
2(载入完成):请求已经发送完成。
3(交互):可以接收到部分响应数据。
4(完成):已经接收到了全部数据,并且连接已经关闭

readyState状态状态说明
(0)未初始化
此阶段确认XMLHttpRequest对象是否创建,并为调用open()方法进行未初始化作好准备。值为0表示对象已经存在,否则浏览器会报错--对象不存在。

(1)载入
此阶段对XMLHttpRequest对象进行初始化,即调用open()方法,根据参数(method,true)完成对象状态的设置。并调用send()方法开始向服务端发送请求。值为1表示正在向服务端发送请求。

(2)载入完成
此阶段接收服务器端的响应数据。但获得的还只是服务端响应的原始数据,并不能直接在客户端使用。值为2表示已经接收完全部响应数据。并为下一阶段对数据解析作好准备。

(3)交互
此阶段解析接收到的服务器端响应数据。即根据服务器端响应头部返回的MIME类型把数据转换成能通过responseBody、responseText或responseXML属性存取的格式,为在客户端调用作好准备。状态3表示正在解析数据。

(4)完成
此阶段确认全部数据都已经解析为客户端可用的格式,解析已经完成。值为4表示数据解析完毕,可以通过XMLHttpRequest对象的相应属性取得数据。

概而括之,整个XMLHttpRequest对象的生命周期应该包含如下阶段:

创建-初始化请求-发送请求-接收数据-解析数据-完成


对象XMLHttpRequest属性status的含义:

100——客户必须继续发出请求(Continue)

101——客户要求服务器根据请求转换HTTP协议版本(Switching protocols)

200——交易成功(OK)

201——提示知道新文件的URL(Created)

202——接受和处理、但处理未完成(Accepted)

203——返回信息不确定或不完整(Non-Authoritative Information)

204——请求收到,但返回信息为空(No Content)

205——服务器完成了请求,用户代理必须复位当前已经浏览过的文件(Reset Content)

206——服务器已经完成了部分用户的GET请求(Partial Content)

300——请求的资源可在多处得到(Multiple Choices)

301——删除请求数据(Moved Permanently)

302——在其他地址发现了请求数据(Found)

303——建议客户访问其他URL或访问方式(See Other)

304——客户端已经执行了GET,但文件未变化(Not Modified)

305——请求的资源必须从服务器指定的地址得到(Use Proxy)

306——前一版本HTTP中使用的代码,现行版本中不再使用

307——申明请求的资源临时性删除(Temporary Redirect)

400——错误请求,如语法错误(Bad Request)

401——请求授权失败(Unauthorized)

402——保留有效ChargeTo头响应(Payment required)

403——请求不允许(由于服务器上文件或目录的权限设置导致资源不可用)(Forbidden)

404——没有发现文件查询或URl(没有找到指定的资源)(Not Found)

405——用户在Request-Line字段定义的方法不允许(Method Not Allowed)

406——根据用户发送的Accept拖,请求资源不可访问(Not Acceptable)

407——类似401,用户必须首先在代理服务器上得到授权(Proxy Authentication required)

408——客户端没有在用户指定的饿时间内完成请求(Request Timeout)

409——对当前资源状态,请求不能完成(Conflict)

410——服务器上不再有此资源且无进一步的参考地址(Gone)

411——服务器拒绝用户定义的Content-Length属性请求(Length required)

412——一个或多个请求头字段在当前请求中错误(Precondition Failed)

413——请求的资源大于服务器允许的大小(Request Entity Too Large)

414——请求的资源URL长于服务器允许的长度(Request-URI Too Long)

415——请求资源不支持请求项目格式(Unsupported Media Type)

416——请求中包含Range请求头字段,在当前请求资源范围内没有range指示值,请求也不包含If-Range请求头字段(Requested Range Not Suitable)

417——服务器不满足请求Expect头字段指定的期望值,如果是代理服务器,可能是下一级服务器不能满足请求(Expectation Failed)

500——服务器产生内部错误(Internal Server Error)

501——服务器不支持请求的函数(Not Implemented)

502——服务器暂时不可用,有时是为了防止发生系统过载(Bad Gateway)

503——服务器过载或暂停维修(Service Unavailable)

504——关口过载,服务器使用另一个关口或服务来响应用户,等待时间设定值较长(Gateway Timeout)

505——服务器不支持或拒绝支请求头中指定的HTTP版本(HTTP Version Not Supported )

12029——网络不通.刷新一下就知道了

猜你在找的Ajax相关文章