原生ajax readystatechange事件请求失败 onload成功的原因分析

       用ajax链接后台接口,请求失败。参数检查没问题,请求得到的responseText也做了对象处理。把onreadystatechange改成onload事件后,请求成功。

xhr.open("get",url,true);
xhr.send();
xhr.οnlοad= function () {            	
     if(xhr.status >=200 && xhr.status < 300 ||xhr.status ==304){
          alert(xhr.responseText);
           alert("请求成功");
      }
      else {
           alert("失败原因:"+xhr.status);
      }
}

           
            

原因是onreadystatechange事件有跨浏览器兼容性的问题,它必须放在在xhr.open()之前。

否则,就会出现请求失败,而xhr.onload()事件则可以写在xhr.open()的后面,所以,上个例子如果想使用onreadystatechange来实现,把xhr.open()和xhr.send()放到最后,然后把onload改成onreadystatechange,加if(xhr.readyState ==4){}即可。代码如下:

xhr.onreadystatechange= function () {            	
    if(xhr.readyState == 4){
       if(xhr.status >=200 && xhr.status < 300 ||xhr.status ==304){
           alert(xhr.responseText);
      }
      else {
           alert("失败原因:"+xhr.status);
      }
}
xhr.open("get",url,true);
xhr.send();
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值