[英]Call same service multiple times at the same time
我有一個$http
服務(或工廠)。
angular.module("app")
.factory("PriceService", function ($http) {
return {
get: function (item) {
var url = "/pricing";
return $http.post(url, item);
}
}
});
我正在從Excel文件中讀取項目。 每個項目將調用一次服務。
for (item in excelItems) {
console.time(item.referenceId);
PriceService.get(item).then(function(response) {
console.timeEnd(item.referenceId);
// process result
}, function() {
// error
})
}
for循環立即完成,因此所有項目都應幾乎同時調用PriceService
。 但是,似乎這些項目正在一個接一個地調用服務。 請查看控制台時間結果(左列為RefereceId)。
3: 2283.264ms
5: 3167.943ms
2: 3327.372ms
11: 3767.073ms
12: 3849.267ms
14: 5388.853ms
8: 15996.263ms
16: 16636.952ms
4: 17689.306ms
18: 18190.733ms
15: 19323.512ms
20: 20009.020ms
13: 23326.644ms
10: 23378.259ms
22: 24077.294ms
24: 24568.147ms
total: 24570.348ms
有什么辦法可以改善這個狀況? 非常感謝!
您可以使用其他方法。 如果每個請求都是冪等的,則可以通過以下方式使用$ q模塊:
var promises = [];
for (item in excelItems) {
promises.push(PriceService.get(item));
}
$q.all(promises).then(function(results){
//Ok
}, function(error){
console.log(error);
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.