Javascript 在配置中使用带有$http和$q的服务/提供程序

Javascript 在配置中使用带有$http和$q的服务/提供程序,javascript,angularjs,promise,Javascript,Angularjs,Promise,我想在app.config节中为每个控制器加载一些配置。每个控制器需要加载一组不同但非互斥的数据。我想不出如何才能做到这一点 .config(['$routeProvider', '$locationProvider', function($routeProvider, $locationProvider){ $routeProvider .when('/', { templateUrl: "partials/pages/dashboard.

我想在app.config节中为每个控制器加载一些配置。每个控制器需要加载一组不同但非互斥的数据。我想不出如何才能做到这一点

.config(['$routeProvider', '$locationProvider', 
        function($routeProvider, $locationProvider){


    $routeProvider
    .when('/', {
        templateUrl: "partials/pages/dashboard.html",
        controller: "dashboard_controller",
        resolve: { dash_config: 'SomeConfigD'},
    })
    .when('/a', {
        templateUrl: "partials/pages/a.html",
        controller: "a_controller",
        resolve: { dash_config: 'SomeConfigA'},
    })
}])
但是,我不想为
someConfigA
someConfigD
编写单独的工厂,因为它们共享代码。我想要像这样的东西

app.factory('configFactory', function(...){
    var factory = ;

    function get1(){
        // some $http calls here and return a promise
    }

    function get2(){
        // some $http calls here and return a promise
    }

    function get3(){
        // some $http calls here and return a promise
    }
    factory.configA = function(){
        // return a promise to resolve both get1 and get2
    };
    factory.configD = function(){
        // return a promise to resolve both get2 and get3
    };
})

我该怎么做呢?

听起来你要找的是
$q.all
,你可以阅读

我还做了一个使用您的工厂的示例,尽管我在模块的run方法中这样做,因为我不想处理创建工厂的问题。它看起来像这样:

f.configA = function(){
    var get12 = $q.all([
        get1().then(thenFn),
        get2().then(thenFn)
    ]).then(function() {
        console.log('both resolved');
    });
    return get12;
};
then中的函数仅在两个承诺都已解决时调用(在不同的时间发生,使用
$timeout

现在get函数可以重用了,希望对您有所帮助