Précédent   Forum des professionnels en informatique > Webmasters - Développement Web > JavaScript > Bibliothèques & Frameworks > jQuery
jQuery Forum d'entraide sur le framework jQuery. Avant de poster : Tutoriels jQuery, FAQ jQuery, Tous les tutoriels JavaScript, Toutes les FAQ JavaScript
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 25/08/2011, 18h24   #1
Membre éclairé
 
Homme Gérard Okono
Développeur Web
Inscription : juillet 2006
Messages : 711
Détails du profil
Informations personnelles :
Nom : Homme Gérard Okono
Localisation : Cameroun

Informations professionnelles :
Activité : Développeur Web
Secteur : Administration - Collectivité locale

Informations forums :
Inscription : juillet 2006
Messages : 711
Points : 328
Points : 328
Par défaut xhr.readyState < 4 avec jQuery

Bonjour,
je suis familié avec ajax sans jquery :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
 
	var xhr = getXMLHttpRequest();
	xhr.onreadystatechange = function(){
          if(xhr.readyState == 4 && xhr.status == 200){
                var rst = eval('(' + xhr.responseText + ')');		
		...
 
  	  } else if (xhr.readyState < 4) {
	        ....
          }
	  };
	xhr.open("POST","fichier.php",true);
	xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
	xhr.send()
Comment faire cela avec jquery. En fait je sais pas comment gérer ceci :
Code :
1
2
3
4
5
6
7
 
if(xhr.readyState == 4 && xhr.status == 200){
    var rst = eval('(' + xhr.responseText + ')
     ...
} else if (xhr.readyState < 4) {
....
}
En fait l'idée pour moi est de gérer un loader tant que xhr.readyState < 4

Merci d'avance...
okoweb est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/08/2011, 11h11   #2
Membre éclairé
 
Homme Gérard Okono
Développeur Web
Inscription : juillet 2006
Messages : 711
Détails du profil
Informations personnelles :
Nom : Homme Gérard Okono
Localisation : Cameroun

Informations professionnelles :
Activité : Développeur Web
Secteur : Administration - Collectivité locale

Informations forums :
Inscription : juillet 2006
Messages : 711
Points : 328
Points : 328
Bonjour,
dans mes recherches j'ai fait ceci :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
 
var xhr=$.ajax({
    type: "POST",
    url: "fichier.php",
    data: null
  });
 
xhr.onreadystatechange = function(){
          if(xhr.readyState == 4 && xhr.status == 200){
                var rst = eval('(' + xhr.responseText + ')');		
		...
 
  	  } else if (xhr.readyState < 4) {
	        ....
          }
	  };
  };
Je n'ai pas testé, y'a pas mieux avec jquery ?
okoweb est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/08/2011, 12h11   #3
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 807
Détails du profil
Informations personnelles :
Nom : Homme Didier Mouronval
Âge : 41
Localisation : France, Gironde (Aquitaine)

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : juin 2008
Messages : 13 807
Points : 35 789
Points : 35 789
Non, à ma connaissance, jQuery n'apporte pas de gestion du readyState pendant la requête.
Ensuite, la bonne question est de savoir à quoi cela est utile, car en réalité, seul le readyState 3 peut avoir un intérêt et encore, dans des cas très restreints, notamment lorsque les données reçues sont volumineuses (parce que dans la plupart des cas, les données reçues le sont en un seul paquet et il n'y a pas de différence entre l'état 3 et l'état 4).
Citation:
En fait l'idée pour moi est de gérer un loader tant que xhr.readyState < 4
Dans ton cas, ce type de gestion est inutilement alourdi, tu peux utiliser avantageusement le beforeSend() par exemple et le success ou le complete.
__________________
Pas de question technique par MP !
Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
Vous possédez un blog et aimeriez diffuser vos billets sur le forum, contactez-moi !
Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
Mon livre sur jQuery
Bovino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/08/2011, 12h53   #4
Membre éclairé
 
Homme Gérard Okono
Développeur Web
Inscription : juillet 2006
Messages : 711
Détails du profil
Informations personnelles :
Nom : Homme Gérard Okono
Localisation : Cameroun

Informations professionnelles :
Activité : Développeur Web
Secteur : Administration - Collectivité locale

Informations forums :
Inscription : juillet 2006
Messages : 711
Points : 328
Points : 328
Citation:
Envoyé par Bovino Voir le message
tu peux utiliser avantageusement le beforeSend() par exemple et le success ou le complete.
Pour bien m'expliquer, je souhaite dans une div, rendre visible une image de préchargement lors de l'attente du résultat ajax et une fois le retour de la réponse remplacer cette image par le contenu de retour.
Code :
1
2
3
4
5
6
7
8
9
 
$.ajax({
   type: "POST",
   url: "fichier.php",
   data: "name=John&location=Boston",
   success: function(msg){
     $("#elt").html(msg);
   }
 });
Comment adapter ce code à ce que je souhaite faire ?

Merci d'avance...
okoweb est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/08/2011, 13h08   #5
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 807
Détails du profil
Informations personnelles :
Nom : Homme Didier Mouronval
Âge : 41
Localisation : France, Gironde (Aquitaine)

Informations professionnelles :
Activité : Développeur Web
Secteur : High Tech - Éditeur de logiciels

Informations forums :
Inscription : juin 2008
Messages : 13 807
Points : 35 789
Points : 35 789
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
$.ajax({
   type: "POST",
   url: "fichier.php",
   data: "name=John&location=Boston",
   beforeSend: function(){
      // affiche l'image
   },
   complete: function(){
      // efface l'image
   },
   success: function(msg){
     $("#elt").html(msg);
   }
 });
__________________
Pas de question technique par MP !
Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
Vous possédez un blog et aimeriez diffuser vos billets sur le forum, contactez-moi !
Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
Mon livre sur jQuery
Bovino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 26/08/2011, 13h49   #6
Membre éclairé
 
Homme Gérard Okono
Développeur Web
Inscription : juillet 2006
Messages : 711
Détails du profil
Informations personnelles :
Nom : Homme Gérard Okono
Localisation : Cameroun

Informations professionnelles :
Activité : Développeur Web
Secteur : Administration - Collectivité locale

Informations forums :
Inscription : juillet 2006
Messages : 711
Points : 328
Points : 328
Citation:
Envoyé par Bovino Voir le message
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
$.ajax({
   type: "POST",
   url: "fichier.php",
   data: "name=John&location=Boston",
   beforeSend: function(){
      // affiche l'image
   },
   complete: function(){
      // efface l'image
   },
   success: function(msg){
     $("#elt").html(msg);
   }
 });
Merci...
okoweb est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 02h57.


 
 
 
 
Partenaires

Hébergement Web