Javascript 在配置中使用带有$http和$q的服务/提供程序
我想在app.config节中为每个控制器加载一些配置。每个控制器需要加载一组不同但非互斥的数据。我想不出如何才能做到这一点Javascript 在配置中使用带有$http和$q的服务/提供程序,javascript,angularjs,promise,Javascript,Angularjs,Promise,我想在app.config节中为每个控制器加载一些配置。每个控制器需要加载一组不同但非互斥的数据。我想不出如何才能做到这一点 .config(['$routeProvider', '$locationProvider', function($routeProvider, $locationProvider){ $routeProvider .when('/', { templateUrl: "partials/pages/dashboard.
.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函数可以重用了,希望对您有所帮助