js與jQuery終止正在發送的ajax請求的方法_AJAX相關

來源:互聯網
上載者:User

本文執行個體講述了js與jQuery終止正在發送的ajax請求的方法。分享給大家供大家參考,具體如下:

核心:調用XMLHttpRequest對象上的abort方法

jquery的ajax方法有自己的逾時時間設定參數:

$.ajax({type:'POST',  url:'b.php',  data:'',  timeout:5000,  success:function(){  }})

同時

1. $.get返回的資料類型是XMLHttpRequest,請參考手冊。($.post、$.ajax、$.getJSON、$.getScript也同樣)

2. XMLHttpRequest對象有abort()方法

也可以自己手動去調用abort方法:

<script src = "jquery-1.4.4.js"></script><script>var xhr = $.ajax({type:'POST',  url:'b.php',  data:'',  success:function(){    alert('ok');  }})alert(xhr);console.log(xhr);</script><button id="song">abort</button><script>$(function(){  $("#song").click(function(){    alert('click');    xhr.abort();  })})</script>

對於原生的xhr:

xmlHttp.open("POST","theUrl",true);xmlHttp.onreadystatechange=function(){  ...//得到響應之後的操作}xmlHttp.send();//設定8秒鐘後檢查xmlHttp對象所發送的資料是否得到響應.setTimeout("CheckRequest()","8000");function CheckRequest(){  //為4時代表請求完成了    if(xmlHttp.readyState!=4){    alert('響應逾時');    //關閉請求    xmlHttp.close();  }}

希望本文所述對大家ajax程式設計有所協助。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.