2017-01-23 70 views
0

我有一個load_graphs函數,它執行AJAX調用創建一個圖形。調用多個AJAX調用相同的函數一個接一個

需要多次調用load_graphs函數來爲不同區域生成周期,如下所示。

儘管調用是使用包裝函數順序完成的,但它的調用是異步的。我怎樣才能一個接一個地調用同一個AJAX函數。

function load_all_graphs(){ 
    load_graphs('national','','container-natl-rates','container-natl-counts') 
    load_graphs('division','Western','container-west-rates','container-west-counts') 
} 

load_all_graphs() 


var load_graphs = function(scope, scopeFilter, chart_1, chart_2){ 
      d = new Date() 
      starttime = d.setMonth(d.getMonth()-1) 
      starttime = d.setDate(d.getDate()-1) 
      endtime = (new Date).getTime() 
      // console.log('starttime == ', starttime) 
      // console.log('endtime == ', endtime) 
      if (scope == 'national'){ 
       url = 'http://99.88.53.222:8081/vp.0.1-SNAPSHOT/Metrics?scope='+ scope + '&interval=day&startTime='+starttime+'&endTime='+ endtime 
      }else { 
       url = 'http://99.88.53.222:8081/vp.0.1-SNAPSHOT/Metrics?scope=' + scope + '&scopeFilter=' + scopeFilter + '&interval=day&startTime='+starttime+'&endTime='+ endtime 
      } 
      if (scopeFilter == ''){ 
       data_filter = 'national' 
      } 
      else if (scopeFilter == 'Western'){ 
       data_filter = 'Western' 
      } 

      $.ajax({type:'GET', 
       url: url,    
       // async: false,   
       success: function(data){      
        // console.log(JSON.stringify(data)) 
        // console.log(data) 
        $.each(data,function(i,x){      
         console.log('national == ', x[0]['X1'])             
         console.log('national data_filter == ', data_filter)             
         console.log('national == ', x[0]['X1'][data_filter])             

         for (var i = 0; i <= 10; i++) 
         { 
          error_counts_results[i] = [] 
         } 
         $.each(x[0]['X1'][data_filter], function(unix_date,data){         
          if (parseFloat(unix_date)){ 
           $.each(error_constants, 
            function(ix,error_item){ 
             // console.log(ix) 
             // console.log(data[error_item]) 
             error_counts_results[ix].push([parseInt(unix_date),data[error_item]]) 
            } 
           ) 
          // console.log('result == ', JSON.stringify(error_counts_results)) 
          }       
         }) 
        }) 
        seriesOptions[0] = { 
         name: error_constants[5], 
         data: error_counts_results[5] 
        }; 
        console.log('option 1 == ', seriesOptions[0]) 
        seriesOptions[1] = { 
         name: error_constants[0], 
         data: error_counts_results[0] 
        }; 
        console.log('option 2 == ', seriesOptions[1]) 
        seriesOptions[2] = { 
         name: error_constants[3], 
         data: error_counts_results[3] 
        }; 
        console.log('option 3 == ', seriesOptions[2]) 
        params = { 
         'title':'National' 
         ,'y2axis':'pct' 
        }         
        createChart_National(chart_1,params); 
        seriesOptions[0] = { 
         name: error_constants[4], 
         data: error_counts_results[4] 
        }; 

        seriesOptions[1] = { 
         name: name, 
         data: error_counts_results[1] 
        }; 

        seriesOptions[2] = { 
         name: name, 
         data: error_counts_results[2] 
        }; 
        params = { 
         'title':'National' 
         ,'y2axis':'cnt' 
        }         
        createChart_National(chart_2,params); 

       },     
      }) 

     } 
+0

您使用的角度,以一個良好的開端,這是什麼問題?你想等待他們或什麼? –

+0

閱讀有關鏈接異步調用的承諾。 –

+0

@DanielB這個問題建議我爲泛型函數逐個調用..我實現了同樣的功能,但仍然稱爲異步。 – user1050619

回答

0

您可以使用promises將您的ajax調用鏈接在一起,jQuery已經將此內置到ajax函數中。

$.ajax({ // ... }) 
.then (function (arg) 
{ 
    // do something with arg 
}) 
.then (function(){ 

    return $.ajax({ }); // second ajax call, return the promise 

}) 
.done (function(args) 
{ 
    // do something with your final result 
}); 

如果你想在並行查找請求碰上使用promise.all

一般來說,我會推薦閱讀有關的承諾,這裏是http://dailyjs.com/2014/02/20/promises-in-detail/