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] la liste déroulante ne montre aucun résultat


Sujet :

JavaScript

  1. #1
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut [AJAX] la liste déroulante ne montre aucun résultat
    Bonjour,

    J'essaie d'apprendre l'AJAX car je dois lier trois listes déroulantes en essayant de ne pas avoir de rechargement de page.

    Je me suis donc basé sur ce cours :

    http://siddh.developpez.com/articles/ajax/

    J'ai copié/collé le code.

    J'ai créé la table MYSQL avec le code fourni, j'ai appelé ma bd "test".

    Quand j'ouvre la première liste déroulante (Auteurs), je n'obtiens rien.

    D'où pensez-vous que le problème peut provenir ?

    Merci d'avance.

    beegees

  2. #2
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Bonjour,
    Citation Envoyé par beegees Voir le message
    D'où pensez-vous que le problème peut provenir ?
    De ton code

    Montre-le ...

    A+

  3. #3
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut
    Citation Envoyé par E.Bzz Voir le message
    Bonjour,De ton code

    Montre-le ...

    A+
    Bonjour,

    Merci pour ta réponse rapide :

    auteurs.php :

    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
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    <html>
    	<head>
    		<title>Tutoriel Ajax (XHTML + JavaScript + XML)</title>
    		<script type='text/javascript'>
     
    			function getXhr(){
                                    var xhr = null; 
    				if(window.XMLHttpRequest) // Firefox et autres
    				   xhr = new XMLHttpRequest(); 
    				else if(window.ActiveXObject){ // Internet Explorer 
    				   try {
    			                xhr = new ActiveXObject("Msxml2.XMLHTTP");
    			            } catch (e) {
    			                xhr = new ActiveXObject("Microsoft.XMLHTTP");
    			            }
    				}
    				else { // XMLHttpRequest non supporté par le navigateur 
    				   alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest..."); 
    				   xhr = false; 
    				} 
                                    return xhr;
    			}
     
    			/**
    			* Méthode qui sera appelée sur le click du bouton
    			*/
    			function go(){
    				var xhr = getXhr();
    				// On défini ce qu'on va faire quand on aura la réponse
    				xhr.onreadystatechange = function(){
    					// On ne fait quelque chose que si on a tout reçu et que le serveur est ok
    					if(xhr.readyState == 4 && xhr.status == 200){
    						leselect = xhr.responseText;
    						// On se sert de innerHTML pour rajouter les options a la liste
    						document.getElementById('livre').innerHTML = leselect;
    					}
    				}
     
    				// Ici on va voir comment faire du post
    				xhr.open("POST","ajaxLivre.php",true);
    				// ne pas oublier ça pour le post
    				xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
    				// ne pas oublier de poster les arguments
    				// ici, l'id de l'auteur
    				sel = document.getElementById('auteur');
    				idauteur = sel.options[sel.selectedIndex].value;
    				xhr.send("idAuteur="+idauteur);
    			}
    		</script>
    	</head>
    	<body>
    		<form>
    			<fieldset style="width: 500px">
    				<legend>Liste liées</legend>
    				<label>Auteurs</label>
    				<select name='auteur' id='auteur' onchange='go()'>
    					<option value='-1'>Aucun</option>
    					<?
    						mysql_connect("localhost","root","mdp");
    						mysql_select_db("test");
    						$res = mysql_query("SELECT * FROM auteur ORDER BY nom");
    						while($row = mysql_fetch_assoc($res)){
    							echo "<option value='".$row["id"]."'>".$row["nom"]."</option>";
    						}
    					?>
    				</select>
    				<label>Livres</label>
    				<div id='livre' style='display:inline'>
    				<select name='livre'>
    					<option value='-1'>Choisir un auteur</option>
    				</select>
    				</div>
    			</fieldset>
    		</form>
    	</body>
    </html>
    et ajaxLivre.php

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <?php
            echo "<select name='livre'>";
            if(isset($_POST["idAuteur"])){
                    mysql_connect("localhost","root","mdp");
                    mysql_select_db("test");
                    $res = mysql_query("SELECT id,titre FROM livre 
                            WHERE idAuteur=".$_POST["idAuteur"]." ORDER BY titre");
                    while($row = mysql_fetch_assoc($res)){
                            echo "<option value='".$row["id"]."'>".$row["titre"]."</option>";
                    }
            }
            echo "</select>";
    ?>
    Qu'en penses-tu ?

    Merci encore.

    beegees

  4. #4
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Le name de ton 2° select et l'id du div qui le contient peuvent poser problème à IE (qui confond allègrement name et id).
    Essaye avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <select name='les_livres'>
    <option value='-1'>Choisir un auteur</option>
    </select>
    A répercuter dans ton PHP qui remplace ce select ...

    A+

  5. #5
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Au fait
    Citation Envoyé par beegees Voir le message
    Quand j'ouvre la première liste déroulante (Auteurs), je n'obtiens rien.
    tu dois avoir au moins une erreur, soit Javascript (en activant la notification des erreurs de scripts dans ton nav ou en utilisant Firebug ou équivalent), soit PHP (en analysant ton responseText qui doit la récupérer) ...

    Ou alors, c'est que les id stockés dans ta table ne correspondent pas à celui envoyé comme paramètre par Ajax ...

    A+

  6. #6
    Membre éprouvé
    Avatar de beegees
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mars 2004
    Messages
    3 610
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : Enseignement

    Informations forums :
    Inscription : Mars 2004
    Messages : 3 610
    Points : 1 277
    Points
    1 277
    Par défaut
    Citation Envoyé par E.Bzz Voir le message
    Le name de ton 2° select et l'id du div qui le contient peuvent poser problème à IE (qui confond allègrement name et id).
    Essaye avec
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    <select name='les_livres'>
    <option value='-1'>Choisir un auteur</option>
    </select>
    A répercuter dans ton PHP qui remplace ce select ...

    A+
    Citation Envoyé par E.Bzz Voir le message
    Au fait
    tu dois avoir au moins une erreur, soit Javascript (en activant la notification des erreurs de scripts dans ton nav ou en utilisant Firebug ou équivalent), soit PHP (en analysant ton responseText qui doit la récupérer) ...

    Ou alors, c'est que les id stockés dans ta table ne correspondent pas à celui envoyé comme paramètre par Ajax ...

    A+
    Salut,

    Merci pour ta réponse.

    En fait j'utilise toujours firefox.

    Je ne comprends pas car c'est un copié collé du code dont j'ai communiqué l'URL, cours de developpez.com.

    Je vais essayer de voir avec firebug (que je ne sais pas utiliser) et je te dis quoi.

    Edit : y'a-t'il une manipulation à faire avec le firebug ?

    Merci encore

    beegees

  7. #7
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Dans Firefox, tu as déjà la console d'erreur (menu Outils) ...

    A+

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

Discussions similaires

  1. [AJAX] 3 listes déroulantes ajax
    Par neoboy dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 31/08/2007, 15h38
  2. Réponses: 3
    Dernier message: 24/05/2007, 11h23
  3. [AJAX] ASP liste déroulantes pays departement ville
    Par franfr57 dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 06/04/2007, 08h18
  4. [AJAX] Plusieurs listes déroulantes
    Par max-mag dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 19/01/2007, 14h40
  5. [AJAX] Listes déroulantes
    Par gscorpio dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 04/12/2006, 09h15

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