【轉】使用setInterval對ajax請求做輪詢

爲什麼setInterval 只執行了一次??
代碼如下

<script language=javascript>
    $(function () {
        var test = {
           deg: function (type) {
            alert(type);
              }
          }
         setInterval(test.deg(12), 1000);
      });
</script>

解決辦法:

setInterval(function () { test.deg(12)}, 1000);這樣就可以了。

當條件達到臨界值時,取消

window.clearInterval(clock);

當然實現這種輪詢的另一種思路是,使用遞歸,然後設置一個休眠時間。

var url = 'rest/services/Tools/submitJob';
 var clock=null;
ajaxfunc(url, 'POST', restData, function (res) { //運行分析
     console.log(res.jobId);
     var jobId = res.jobId;
     
    clock =  window.setInterval(function () { result(jobId)}, 5000);
 });
 var result = function(jobId) {
     var url = adminURL + "rest/services/Tools/jobs/" + jobId;
     $.ajax({
         type: "POST",
         url: url,
         dataType: 'json',
         data: {
             f: 'json',
             token: token
         },
         success: function (data) {
             var jobStatus = data.jobStatus;
             if(jobStatus =='esriJobSucceeded'){
                 var output = url + '/results/output';
                 var resultOutput;
                 $.ajax({
                     type: "POST",
                     url: output,
                     dataType: 'json',
                     data: {
                         f: 'json',
                         token: token
                     },
                     success: function (data) {
                         resultOutput = data.value.url;
                         alert(resultOutput)
                         window.clearInterval(clock);
                     },
                     error:function(){
                         alert("error")
                         window.clearInterval(clock);
                     }
                 });
             }
             if(jobStatus =='esriJobFailed'){
                 alert("esriJobFailed")
                 window.clearInterval(clock);
             }         
         },
         error: function () {
             alert("error")
             window.clearInterval(clock);
         }

     });
 };
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章