angularjs – Angular .controller()在.run()之前运行

前端之家收集整理的这篇文章主要介绍了angularjs – Angular .controller()在.run()之前运行前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在.run()中有一个ajax调用,它将一个变量加载到$rootScope中
在与视图关联的控制器中需要该变量.

有时在.controller加载时刷新(F5)时,$rootScope.user.fedUnit内部没有任何内容导致:

TypeError:无法读取未定义的属性’fedUnit’

有没有什么方法可以延迟加载控制器直到完成.run()之后?
似乎无法找到它.

app.run(function($rootScope,$http,$location,SessionFactory,TokenHandler) {
    token = TokenHandler.getToken();
    if ( token != null ) {
        SessionFactory.get( { token : token },function success(response,responseHeaders) {
                $rootScope.user = response;
            }
        );
    }
});

app.controller('UnitController',function($scope,$rootScope,UnitFactory) {
    $scope.updateUnits = function () {
        UnitFactory.query({fedUnit: $rootScope.user.fedUnit},responseHeaders) { ...

$rootScope.foo = $q.defer();
$rootScope.foo.resolve(); when AJAX is done;
$rootScope.foo.promise.then(..) in the controller.

感谢@misterhiller(twitter)

解决方法

功能代码块的解决方案:

app.run(function($rootScope,$q,TokenHandler) {

    $rootScope.ajaxCall = $q.defer();

    token = TokenHandler.getToken();
    if ( token != null ) {
        SessionFactory.get( { token : token },responseHeaders) {
                $rootScope.user = response;

                $rootScope.ajaxCall.resolve();
            }
        );
    }
});

app.controller('UnitController',UnitFactory) {

    $scope.ajaxCall.promise.then(function() {
        $scope.updateUnits = function () {
            UnitFactory.query({fedUnit: $scope.user.fedUnit});
        }
    });
});

我不在控制器中使用$rootScope.

猜你在找的Angularjs相关文章