나는 anglejs에 다음 코드를 가지고 있습니다 .run()
그래서 앱이 초기 상태 일 때 rootscope 아래에 2 개의 변수를 설정했습니다. 이 녀석들은 모든 루트 (페이지)와 컨트롤러에서 사용하기로 결정했기 때문입니다. 내 컨트롤러에서 실행할 때 비동기다른 컨트롤러에서 angularjs 초기화 된 변수를 재사용하는 방법
app.run(function($rootScope, $timeout, firebaseAuth) {
$rootScope.$on('firebaseLoggedIn', function(event, authUser) {
$timeout(function() {
$rootScope._isLoggedIn = true;
$rootScope._authUser = authUser;
},0);
});
그러나 여기에서 문제는 항상 정의되지 않은 보여줍니다. 을 기능 블록에 넣지 않는 한. 그래서 제 생각 엔 컨트롤러가 실행되고 있습니다 .run()
이전에 가있었습니다.
app.controller('foo', function($scope){
console.log($scope._authUser); //Always undefined
//unless I do following
//$scope.clickme = function() {console.log($scope._authUser)};
});
제안 사항 .run()에서 vars (async)를 사용할 수 있습니까?
모든 컨트롤러에서 다음 코드를 호출하면 반복되는 것처럼 보입니다.
$rootScope.$on('firebaseLoggedIn', function(event, authUser) {});
UPDATE 여기서 여기서 firebaseLoggedIn 이벤트이다. 나는 다시 언급해야한다고 생각한다. 콜백은 비동기입니다.
app.service('firebaseAuth', ['$rootScope',
function($rootScope) {
//Define firebase DB url
this.firebaseRef = new Firebase("https://test.firebaseio.com");
this.onLoginStateChanges = new FirebaseAuthClient(this.firebaseRef, function(error, user) {
if (user) {
$rootScope.$emit("firebaseLoggedIn", user); //authenticated user
}
else if (error) {
$rootScope.$emit("firebaseLoginError", error); //authentication failed
}
else {
$rootScope.$emit("firebaseLogout"); //user not login
}
});
}]);
시도했지만 작동하지 않습니다. 컨트롤러에서'FirebaseService.getIsLoggedIn()'은 false를 반환합니다. firebaseLoggedIn 이벤트를 수신하지 않기 때문에 나는 생각한다. 내 질문을 다시 확인하십시오. 그것을 업데이트했습니다 – vzhen
$ rootScope를 변경하십시오. $ emit을 $ rootScope. $ broadcast로 변경하십시오. $ emit은 범위를 통해 위쪽으로 이벤트를 디스패치하기위한 것이고, 아래쪽은 $ broadcast입니다. –
운이 없으면 false도 반환하십시오. – vzhen