Zwróć współzależne asynchroniczne obietnice w rozwiązaniu $ routeProvider

Rozważ kod:

var myApp = angular.module('myApp', []);

Trasy:

myApp.config(['$routeProvider', function($routeProvider) {
        $routeProvider.when('/', {
            templateUrl: 'app.html', 
            controller:myAppController, 
            resolve:{
                resolveData:function(Resolver){
                    return Resolver();
                }
            }
        });
    });

Rozwiązać:

myApp.factory('Resolver', ['$http', function($http){
    return function(){
        return $http({url: '/someurl',method: "GET"}).then(function(data) {

            // dependent call 1
            $http({url: '/someotherurl',method: "GET" }).then(function(data) {

            });

            // dependent call 2
            $http({url: '/someanotherurl',method: "GET" }).then(function(data) {

            });
        });
    }
}]);

Powyżej mam zagnieżdżone 2 połączenia wewnątrz jednego, ponieważ są one zależne od danych zwracanych przez wywołanie rodzica.

Co chcę robić: zwróć Resolver, gdy wszystkie z nich zostaną ukończone, a nie tylko połączenie nadrzędne.

Nie mogę użyć $ q.all (), ponieważ 2 połączenia są zależne od pierwszego połączenia.

W skrócie, myAppController musi zostać załadowany dopiero po zakończeniu wszystkich 3 połączeń.

questionAnswers(2)

yourAnswerToTheQuestion