首頁 >web前端 >js教程 >angularjs 處理多個非同步請求方法匯總_AngularJS

angularjs 處理多個非同步請求方法匯總_AngularJS

WBOY
WBOY原創
2016-05-16 16:22:001172瀏覽

在實際業務中經常需要等待幾個請求完成後再進行下一步操作。但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);
        })
    });
});

$q的詳細使用方法網路上的有很多教學。我也是剛接觸。講不好,不敢亂講。上面的程式碼是我照我的理解寫的,經過了測試沒有問題。

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