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

JavaScript Discussion :

[AJAX] Paramètres de handleRequestStateChange()


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 28
    Points : 31
    Points
    31
    Par défaut [AJAX] Paramètres de handleRequestStateChange()
    Bonjour,

    J'utilise AJAX depuis peu pour rendre les contenus de mes sites plus dynamiques et avec moins de rechargements de pages, cependant je souhaiterai pouvoir envoyer différents paramètres à handleRequestStateChange() mais il semblerait que ce ne soit pas vraiment une fonction, donc ça ne fonctionne pas, voici "mon" 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
    function createRequestObject()
     {
    	var http;
    	if (window.XMLHttpRequest)
    	{ // Mozilla, Safari, IE7 ...
    		http = new XMLHttpRequest();
    	}
    	else if (window.ActiveXObject)
    	{ // Internet Explorer 6
    		http = new ActiveXObject("Microsoft.XMLHTTP");
    	}
    	return http;
    }
     
    function handleRequestStateChange()
    {
    	var myDiv=document.getElementById('id_div');	
    	if(http.readyState==4)
    	{
    		if(http.status==200)
    		{
    			try
    			{
    				// lecture du message du serveur
    				response=http.responseText;
    				// affichage du message
    				myDiv.innerHTML=response;
    			}
    			catch(e)
    			{
    				alert("Erreur en lisant la réponse: "+e.toString());	
    			}
    		}
    		else
    		{
    			alert("Problème rencontré en recevant les données:\n"+http.statusText);
    		}
    	}
    }
     
    function maFonctionhttp_1()
    {
    	slink = '/ajax/page_1.php';		
    	http = createRequestObject();	
    	http.open('GET', slink, true);
    	http.onreadystatechange=handleRequestStateChange;
    	http.send(null);	
    }
    function maFonctionhttp_2()
    {
    	slink = '/ajax/page_2.php';		
    	http = createRequestObject();	
    	http.open('GET', slink, true);
    	http.onreadystatechange=handleRequestStateChange;
    	http.send(null);	
    }
    Dans maFonctionhttp_1, maFonctionhttp_2 ... maFonctionhttp_n, je souhaiterais pouvoir indiquer l'élément qui affichera http.responseText de la fonction handleRequestStateChange.

    En indiquant directement dans chque fonction http.onreadystatechange=handleRequestStateChange('id_div'); cela ne fonctionne pas comme indiqué plus haut.

    Que me conseillez-vous ?

    Merci d'avance

  2. #2
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    http.onreadystatechange=function('param'){handleRequestStateChange(param)}
    Au pire, utilises une variable globale où tu stockes dans les fonctions maFonctionhttp_n() l'élément d'affichage.

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 28
    Points : 31
    Points
    31
    Par défaut
    Bonjour,

    Merci de ton aide, mais cela ne fonctionne pas, je me demande si ce ne serait pas plus simple avec jquery et sa fonction Ajax()...

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Septembre 2008
    Messages
    28
    Détails du profil
    Informations personnelles :
    Âge : 50
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Septembre 2008
    Messages : 28
    Points : 31
    Points
    31
    Par défaut
    Re,

    Bon, finalement, 100% plus simple avec jquery :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    function maFonctionhttp_n()
    {
    	slink = '/ajax/monfichier_n.php';		
     
    	var myDiv=document.getElementById('div_n');
    	$.get(slink, function(data)
    	{
      		myDiv.innerHTML=data;
      	}
    	);
    }

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

Discussions similaires

  1. Ajax paramètres espace
    Par surfeur2 dans le forum AJAX
    Réponses: 2
    Dernier message: 09/10/2016, 18h57
  2. Ajax : paramètres POST ne passent pas
    Par Neilime05 dans le forum jQuery
    Réponses: 3
    Dernier message: 20/01/2012, 11h37
  3. [AJAX] File Upload Ajax paramètres.
    Par Pymento dans le forum AJAX
    Réponses: 6
    Dernier message: 26/05/2011, 15h17
  4. ajax paramètre indésirable ?
    Par boboss123 dans le forum jQuery
    Réponses: 2
    Dernier message: 15/02/2010, 09h27
  5. [AJAX] Paramètres de type objet
    Par Mister Nono dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 04/05/2007, 14h03

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