同时多次呼叫同一服务

时间:2016-03-18 15:23:03

标签: javascript angularjs

我有一个$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

有什么方法可以改善这个吗?非常感谢!

1 个答案:

答案 0 :(得分:1)

您可以使用其他方法。 如果每个请求都是幂等的,您可以通过这种方式使用$ q模块:

var promises = [];
for (item in excelItems) {
    promises.push(PriceService.get(item));
}
$q.all(promises).then(function(results){
    //Ok
}, function(error){
    console.log(error);
});