我会以这样一个事实作为开头,我真的不知道这是否是实现我正在做的事情的最佳方式,而且我非常愿意接受更好的建议。
我有一个用户帐户系统,它使用OAUTH2
它在我的数据库中查找用户信息并将其保存为变量,$rootScope.userInfo
. 这驻留在附加到我的应用程序的控制器中body
;在这里,我认为最高级别的控制器会先于其中的控制器加载,但显然不是。
如果我在有机会从我的数据库中加载它之前加载了一个尝试访问该$rootScope.userInfo
对象的视图,它会引发一个 javascript 错误并中断。mainCtrl
Angular
作为参考,这里有一个模板的粗略想法:
<body ng-controller="mainCtrl">
<header>Content</header>
<div class='main-view' ng-controller="userProfile">
<p>{{user.name}}</p>
<p>{{user.email}}</p>
</div>
</body>
我是这样加载$rootScope.userInfo
的mainCtrl
:
$http.get('/api/users/' + $cookies.id).
success(function(data) {
$rootScope.userInfo = data.user[0];
console.log("User info is:");
console.log($rootScope.userInfo);
$scope.status = 'ready';
});
然后为了我的userProfile
控制,我这样做:
function userProfile($scope, $cookies, $http, $routeParams, $rootScope){
if($scope.status == 'ready'){
$scope.user = $rootScope.userInfo;
console.log("Double checking user info, here it is:");
console.log($rootScope.userInfo);
}
}
如果我来自应用程序中未调用的其他页面$rootScope.userInfo
,则 API 有足够的时间查找它并且我的userProfile
页面工作正常。但是,如果进行整页刷新,$rootScope.userInfo
则没有时间加载,并且出现错误。
我怎样才能解决这个问题?