我试图在ui-router继续加载状态之前等待提供程序完成初始化。
每次进入状态时,都应启用摄像头,并且每次再次禁用摄像头时。我将它放入提供者,因为它需要在module.config
级别使用:
.provider("Camera", function CameraProvider() {
function init() {
//async enableCamera
}
function exit() {
//disableCamera
}
function $get() {
return { init: init, exit: exit };
}
});
和州:
var cam = DubCameraProvider.$get(); // this is a hack, but I don't know how to
$stateProvider
.state("CameraState", {
url: "/camera",
onEnter: cam.init,
onExit: cam.exit,
views: {
"view": {
// template: ...,
controller: "ControllerUsingCamera"
}
}
我尝试使用$q
创建承诺并使用resolve
等待,但在module.config
级别,$ q无法注入(或者我只是我知道怎么做?)。
我该如何解决这个问题?
答案 0 :(得分:1)
resolve
带有依赖注入。你可以这样做:
$stateProvider.state("CameraState", {
url: "/camera",
onEnter: cam.init,
onExit: cam.exit,
views: {
"view": {
// template: ...,
controller: "ControllerUsingCamera"
}
},
resolve: {
somethingAsync: function($q) {
var promise = $q.all( /*bunch of promises*/ );
return promise;
}
}
}
答案 1 :(得分:1)
$q
可以在您的州的解析对象中注入而不会出现问题:
配置:
angular.module('app').config([
'$stateProvider',
'$urlRouterProvider',
function ($stateProvider, $urlRouterProvider) {
$urlRouterProvider.otherwise('/');
$stateProvider.state('root', {
'url': '/',
'controller': 'rootController',
'templateUrl': 'root.html',
'resolve': {
'data': [
'$q',
'$timeout',
function ($q, $timeout) {
var deferred = $q.defer();
$timeout(function() {
deferred.resolve({
'value': 'Foo'
});
}, 5000);
return deferred.promise;
}
]
}
});
}
]);
控制器:
angular.module('app').controller('rootController', [
'$scope',
'data',
function ($scope, data) {
$scope.value = data.value;
}
]);
直接来自他们wiki的文档:https://github.com/angular-ui/ui-router/wiki#resolve
这是关于Plunker的一个工作示例:http://plnkr.co/edit/kJ99Hi0qWx7DJxOVzxgA?p=preview