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);
},
})
}
您使用的角度,以一個良好的開端,這是什麼問題?你想等待他們或什麼? –
閱讀有關鏈接異步調用的承諾。 –
@DanielB這個問題建議我爲泛型函數逐個調用..我實現了同樣的功能,但仍然稱爲異步。 – user1050619