IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

AngularJS Discussion :

TypeError: authentication.current is not a function


Sujet :

AngularJS

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2016
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2016
    Messages : 2
    Points : 3
    Points
    3
    Par défaut TypeError: authentication.current is not a function
    Bonjour,

    J'ai un petit problème avec AngularJS.

    J'essaye d'appeler une fonction (depuis un contrôleur) se trouvant dans un service mais Angular me retourne une erreur.

    => Elle se trouve dans une variable => var maVar = function() { //etc... };

    J'ai essayé nomDuService.maVar(); mais j'ai une erreur du genre 'nomDuService.maVar();' is not a function

    Je ne comprend pas pourquoi donc je fait appel à vous

    Voici l'erreur :

    Nom : Erreur AngJS.PNG
Affichages : 182
Taille : 16,7 Ko

    Et le code :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
     
    login.service("authentication", ["$http", "$window", function($http, $window) {
     
      var saveToken = function(token) { // Sauvegarde
        $window.localStorage["mean-token"] = token // Sauve le token en local
      };
     
      var getToken = function() { // Récupération
        return $window.localStorage["mean-token"];
      };
     
      var logout = function() { // Déconneion
        $window.localStorage.removeItem("mean-token");
      };
     
      var isLoggedIn = function(token) {
        var token = getToken();
        var payload;
     
        if (token) {
          payload = token.split(".")[1]; // Split le token lors d'un "." et on retourne l'élément d'index [1]
          payload = $window.atob(payload);  // Décode
          payload = JSON.parse(payload); // Parse en JSON
     
          if (payload.exp > Date.now() / 1000) return true; // True si date n'est pas dépassée
        }
        else {
          return false;
        }
      };
     
      var currentUser = function() { // La fonction en question ==============================
     
        var token = getToken();
        var payload;
     
        if (isLoggedIn()) {
          payload = token.split(".")[1]; // Split le token lors d'un "." et on retourne l'élément d'index [1]
          payload = $window.atob(payload);  // Décode
          payload = JSON.parse(payload); // Parse en JSON
          console.log(payload);
          return {
            mail: payload.mail,
            lastname: payload.lastname
          };
        }
      };
     
      return { // On renvoi tout dans un objet
        saveToken: saveToken,
        getToken: getToken,
        logout: logout,
        isLoggedIn: isLoggedIn
      };
    }]);
     
    // Contrôleur home
    login.controller("MainCtrl", function($rootScope, authentication) {
      $rootScope.title = "Bienvenue"
      $rootScope.sent = false;
     
      //console.log(authentication.isLoggedIn());
     
      $rootScope.isLoggedIn = authentication.isLoggedIn();
      $rootScope.currentUser = authentication.currentUser(); // ICI => TypeError: authentication.currentUser is not a function =======
    });

  2. #2
    Membre expérimenté Avatar de slim
    Homme Profil pro
    Ingénieur développement logiciels
    Inscrit en
    Décembre 2002
    Messages
    938
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Ingénieur développement logiciels
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Décembre 2002
    Messages : 938
    Points : 1 337
    Points
    1 337
    Par défaut
    Salut!

    Seules les fonctions présentes dans l'objet retourné par le service peuvent être appelées.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     return { // On renvoi tout dans un objet
        saveToken: saveToken,
        getToken: getToken,
        logout: logout,
        isLoggedIn: isLoggedIn
      };
    tu ne renvoie tout simplement pas currentUser

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Février 2016
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 27
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant

    Informations forums :
    Inscription : Février 2016
    Messages : 2
    Points : 3
    Points
    3
    Par défaut
    En effet, merci

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. TypeError: this.getViewer is not a function
    Par saxrub dans le forum IGN API Géoportail
    Réponses: 2
    Dernier message: 29/09/2015, 07h14
  2. Extjs 4.2.1 Uncaught TypeError: win.down is not a function
    Par Socrat dans le forum Ext JS / Sencha
    Réponses: 12
    Dernier message: 22/06/2015, 05h37
  3. Réponses: 4
    Dernier message: 23/05/2015, 23h01
  4. TypeError:elem.getAttribute is not a function
    Par felix01 dans le forum Odoo (ex-OpenERP)
    Réponses: 0
    Dernier message: 02/01/2014, 02h07

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo