我在这里看到了一些示例代码Delaying AngularJS route change until model loaded to prevent flicker
然而我马上就知道这是正确的方法,我需要让我的控制器加载只有当一个解决方案完成加载时,通常大多数示例都会告诉你将路由器中的代码解析为内联函数,但这听起来不对。控制器需要它,所以为什么不让控制器实现要解决的功能。这听起来就像我在寻找的那样。这似乎使用了原型模式??
function PhoneListCtrl($scope, phones) {
$scope.phones = phones;
$scope.orderProp = 'age';
}
PhoneListCtrl.resolve = {
phones: function(Phone, $q) {
// see: https://groups.google.com/forum/?fromgroups=#!topic/angular/DGf7yyD4Oc4
var deferred = $q.defer();
Phone.query(function(successData) {
deferred.resolve(successData);
}, function(errorData) {
deferred.reject(); // you could optionally pass error data here
});
return deferred.promise;
}
}
问题是我的控制器是这样的
'use strict';
angular.module('TestApp')
.controller('ItemsCtrl', function ($scope) {
});
那么当我的控制器在模块内声明时,如何在控制器上应用新功能?
我真正需要的是像
TestCtrl.resolve = {
items: function( $q) {
..........
return deferred.promise;
}
}
然后这将允许我拥有我的routeprovider ..
when('/items', {
templateUrl: 'views/items.html',
controller: 'TestCtrl',
resolve: 'TestCtrl.resolve'}). // Need to use ' around resolve?
但我很困惑如何让它发挥作用?
我真的很喜欢任何反馈,我很茫然。
答案 0 :(得分:7)
如果要使用.controller语法使用resolve,则无法定义类似'TestCtrl.resolve',那么您必须在路由提供程序中定义内联。 routeprovider中内联解析的优点是您可以轻松地重用控制器,但使用相同的控制器并更改解析函数中的逻辑
答案 1 :(得分:4)
您也可以使用服务:
resolve: {data : function(service) {
return service.getData();
}}