Прозрачный ионоскоп

Привет, я делаю логин для ионного приложения..... и я использую 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
  }

  ...
}
Другие вопросы по тегам