Bonjour,
ça fait peu de temps que je me suis mis à Mootools pour les dèv javascipts.
J'ai pu avancer facilement avec la doc d'origine, mais là je bloque sur un point. Et ce n'est pas forcément lié à mootools mais au modèle objet de javascript je pense.
j'ai un objet myObj dont l'une de ses méthodes va utiliser la classe Json. L'objectif c'est de tester les entrées de l'objet person via l'objet myObj. Si c'est un succès il faut que je retire l'entrée de myObj.aPersonToCheck, si c'est un echec je dois afficher le message retourné par mon script php.
Ce script php retourne un entete http 200 si ok, et 5xx si nok
Le problème que j'ai se trouve au niveau des fonctions déclarés au niveau de l'appel Json : je n'arrive pas à passer à ces fonctions quelques paramètres que ce soit, comment savoir si onSuccess concerne la person0 ou la person1 ?
j'ai tenté en déclarant une variable temporaire myObj.curPerson ou var curPerson au sein de la méthode doCall, mais jamais je n'ai l'information.
En fait j'ai l'impression, que la boucle for lance tous les appels Json sans attendre le retour (ce qui est plutôt intéressant car ça ne bloque pas le processus). Les fonctions déclarés lors des onSuccess, onchange, onComplete... n'ont pas accès à grand chose : comment accéder au retour de l'appel XHR (body, header,) ? peut on leur spécifier des paramètres ?
voici un exemple de code concerné :
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 <script> var person = new Array() ; person[0] = { name:'myName', age:25, job:'noob' }; person[1] = { name:'toto', age:1, job:'looser' } var myObj = { aPersonToCheck:'', doCall: function( oPerson ){ aPersonToCheck= person ; for( sKey in aPersonToCheck) { jSonRequest = new Json.Remote("doCheckPerson.php", { onFailure: function(){ alert( this) ; }, onSuccess: function(){ alert( this) ; }, onStateChange: null, onComplete: function( oPersonJson ){ alert( this) ; } }).send( Json.toString( oPerson ) ) ; } } </script>
Partager