首頁  >  文章  >  web前端  >  angularjs如何處理多個非同步請求的方法總結

angularjs如何處理多個非同步請求的方法總結

伊谢尔伦
伊谢尔伦原創
2017-07-21 14:27:222057瀏覽

在實際業務中經常需要等待幾個請求完成後再進行下一步操作。但angularjs中$http不支援同步的請求。

解決方法一:

$http.get('url1').success(function (d1) {
        $http.get('url2').success(function (d2) {
            //处理逻辑
        });
    });

解決方法二:

then中的方法會依序執行。

var app = angular.module('app',[]);
app.controller('promiseControl',function($scope,$q,$http) {
    function getJson(url){
        var deferred = $q.defer();
        $http.get(url)
            .success(function(d){
                d = parseInt(d);
                console.log(d);
                deferred.resolve(d);
            });
        return deferred.promise;
    }
    getJson('json1.txt').then(function(){
        return getJson('json2.txt');
    }).then(function(){
        return getJson('json1.txt');
    }).then(function(){
        return getJson('json2.txt');
    }).then(function(d){
        console.log('end');
    });
});

解決方法三:

$q.all方法第一個參數可以是陣列(物件)。在第一參數中內容都執行完後就會執行then中方法。第一個參數的方法的所有回傳值會以數組(物件)的形式傳入。

var app = angular.module('app',[]);
app.controller('promiseControl',function($scope,$q,$http) {
    $q.all({first: $http.get('json1.txt'),second: $http.get('json2.txt')}).then(function(arr){
        console.log(arr);
        angular.forEach(arr,function(d){
            console.log(d);
            console.log(d.data);
        })
    });
});

以上是angularjs如何處理多個非同步請求的方法總結的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn