Bonsoir,
J'ai une application angular & ionic avec un input (ion-input) :
- je stocke la valeur entrée par l'utilisateur dans ma BDDFirebase
- je récupère cette valeur pour l'assigner comme valeur par défaut de mon input //mon problème
Lorsque je récupère cette valeur en BDD, je n'arrive pas à l'assigner comme valeur de mon input car je n'ai pas accès au this qui me permet de référer aux variables de la classe this.maVariable
Code HTML : Sélectionner tout - Visualiser dans une fenêtre à part <ion-input placeholder="Pseudo" [(ngModel)]="todo.pseudo" (change)="onPseudoChange()"></ion-input>
TS
Ce que j'ai déjà essayé
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 export class ProfilPage { todo = {} user_profil = {} as Profil; public pseudo: string; constructor(public navCtrl: NavController, afDB: AngularFireDatabase, public events: Events) { /*events.subscribe('pseudo_ready', () => { console.log("pseudo_ready ==> "+"pseudo"); }); */ console.log('ProfilPage', "salut ProfilPage"); //this.pseudo="test"; // fonctionne this.load_info(); } ionViewDidLoad() { console.log('ionViewDidLoad ProfilPage', 'ProfilPage'); } load_info() { let user = firebase.auth().currentUser; var url = firebase.database().ref(user.id+'/'+'user_profil'); url.once("pseudo") .then(function(snapshot) { let pseudo_fire = snapshot.child("pseudo").val(); console.log('load_info', " load_info pseudo_fire "+pseudo_fire); //this.put_info(pseudo_fire); //this.todo['pseudo'] = pseudo_fire; //todo['pseudo'] = pseudo_fire; //this.todo.pseudo=pseudo_fire; //todo.pseudo=pseudo_fire; //this.pseudo=pseudo_fire; console.log("pseudo", "pseudo= "+pseudo); // afficher la valeur marche :) }, function(error) { console.log("erreur de la promise load_info()"); }); //this.events.publish('pseudo_ready'); } }
- la valeur récupérée depuis Firebase s'affiche bien dans le then() grâce à console.log() mais je ne peux la récupérer dans une variable de classe ou l'assigner directement comme valeur de mon ion-input.
- j'utilise l'objet todo pour stocker toutes les valeurs de ma page à afficher.
- j'ai tenté d'utiliser sans succès une variable de class pseudo: string
- j'ai tenté d'appeler une autre fonction mais sans succès tjrs
- j'ai tenté d'émettre un événement dans le then une fois la promise réussie mais je n'ai toujours pas accès au this.events, d'autre part si je ne le fais pas dans then() la promise n'est pas encore finie avant émission de l' event qui émet donc une valeur undefined
- j'ai tenté sans succès d'assigner la valeur de ma promise dans mon ion-input comme dans le code suivant :
Code : Sélectionner tout - Visualiser dans une fenêtre à part
1
2
3
4
5 this.todo['pseudo'] = url.once("pseudo") .then(function(snapshot) { [...] // M'affiche Object[Object] }});
Je comprend que cette fonction est asynchrone mais pourriez m'expliquer comment assigner le résultat de ma promise comme valeur par défaut de mon <ion-input> svp ?
Partager