Прозрачный ионоскоп
Привет, я делаю логин для ионного приложения..... и я использую rootcope как глобальную переменную для использования во всех контроллерах (LoginCtrl,SalirCtrl). Когда пользователь входит в систему, я сохраняю его информацию в переменной rootcope и показать эту информацию в SalirCtrl.
BUt, когда пользователь выходит из системы и другой пользователь входит в систему, его информация отсутствует в SalirCtrl.
Кто-то знает об этом.
LoginCtrl
if($scope.datos=='true') {//if token is true. User is log-in
$rootScope.pNombre=data.persona.primerNombre;
$rootScope.sNombre=data.persona.segundoNombre;
$rootScope.pApellido=data.persona.primerApellido;
$rootScope.sApellido=data.persona.segundoApellido;
$state.go('tabs.perfil');
}
SalirCtrl
.controller('SalirCtrl', function($scope, $state, $ionicPopup, ServUsuario,$rootScope,$ionicHistory) {
//para bloquear el boton atras
$ionicHistory.nextViewOptions({
disableAnimate: true,
disableBack: true
});
//FIN para bloquear el boton atras
$scope.pNombre = $rootScope.pNombre;//save in a scope variable rootscope
$scope.sNombre = $rootScope.sNombre;
$scope.pApellido = $rootScope.pApellido;
$scope.sApellido = $rootScope.sApellido;
//METODO SALIR
$scope.salir = function() {
var confirmPopup = $ionicPopup.confirm({
title: 'Log-out',
template: '¿Log-out?'
});
confirmPopup.then(function(res) {
if(res) {
console.log('You are sure');
$state.go('login');
$scope.pNombre=" "; //When log-out is true. Variables equals empty
$scope.sNombre=" ";
$scope.pApellido=" ";
$scope.sApellido=" ";
} else {
console.log('You are not sure');
}
});
};
//FIN METODO SALIR
})
Наконец я печатаю эти переменные в perfil.html
{{pNombre}} {{sNombre}} {{pApellido}} {{sApellido}}
Спасибо....!
2 ответа
Я предполагаю, что вы страдаете от кеширования в AngularJS UI-Router. Что происходит в конфигурации вашего маршрута, когда вы делаете что-то подобное?:
$stateProvider.state('myState', {
cache: false,
url : '/myUrl',
templateUrl : 'my-template.html'
})
По умолчанию Ionic кэширует представления, как описано здесь:
http://ionicframework.com/docs/api/directive/ionNavView/
Когда представления кэшируются, ваши контроллеры не перезагружаются во время навигации. Дайте мне знать, если это сработало?
Лучший,
Ваша цель - внедрить пользовательскую службу, которая может хранить учетные данные пользователя и к которым можно получить доступ со всех ваших контроллеров. Смотрите пример реализации ниже:
angular.module('your-app').service('myUserService', myUserService);
function myUserService() {
var _identity = null;
return {
getUser: getUser,
setUser: setUser,
login: login,
logout: logout
...
};
function getUser() {
return _identity;
}
function setUser(user) {
_identity = user;
}
function login() {
//your login logic here
}
function logout() {
_identity = null;
//other logout logic
}
...
}