• 如何中断ajax请求【学习笔记】


    停止javascript的ajax请求有两种方式

          1.  设置超时时间让ajax自动断开

          2.  手动去停止ajax请求,

                核心是调用XMLHttpRequest对象上的abort方法

                 我们以jquery举例说明:

                  jquery的ajax对象的abort方法:调用abort后jquery会执行error的方法,抛出abort的异常信息,此时即可执行我们中断ajax后的操作。

    var ajax = $.ajax({
    'error':function(jqXHR, textStatus, errorThrown){
    if(errorThrown != 'abort'){
    //ajax被调用abort后执行的方法
    alert('您的ajax方法被停止了');
            }
        }
    })
    
    ajax.abort();//停止ajax
    

      原生js:

    xmlHttp.open("POST","Url",true);
     xmlHttp.onreadystatechange=function(){
     ...//得到响应之后的操作
     }
     xmlHttp.send();
     //设置3秒钟后检查xmlHttp对象所发送的数据是否得到响应.
     setTimeout("CheckRequest()","3000");
     function CheckRequest(){
     //为4时代表请求完成了
     if(xmlHttp.readyState!=4){
     alert('数据响应超时');
     //关闭请求
     xmlHttp.close();
     }
     }
    //根据响应状态的改变关闭

      切记:不可用abort方法来作为终止对服务器的请求操作,只有当做在前端页面立刻停止执行ajax成功后的方法,因为你执行abort方法后,ajax很可能已经对服务端发送了请求,只是还未返回回馈信息而已。

    原文:你的名字~

  • 相关阅读:
    04.openssl-创建 Root CA证书
    03.openssl-获得支持加密算法
    02.openssl-密钥的格式转换
    01.openssl-创建证书签名请求
    00.openssl key generation
    03.openssl中设计中小提示
    会员手机运营商统计
    将属性和方法添加到Date原型中
    AngularJS 指令(意义)
    统计字符串中数字,字母,空格的个数
  • 原文地址:https://www.cnblogs.com/qingfengyuan/p/13474208.html
Copyright © 2020-2023  润新知