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

PHP & Base de données Discussion :

Remplir une liste déroulante en utilisant AJAX et PHP


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé
    Inscrit en
    Mai 2010
    Messages
    128
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 128
    Par défaut Remplir une liste déroulante en utilisant AJAX et PHP
    Bonjour;
    j'ai tombé dans une situation dont j'ai pas pu détecté le problème.
    j'ai 2 listes déroulantes remplies manuellement et je voudrais remplir la 3 eme dynamiquement en utilisant AJAX et PHP.
    Bon; pour ce faire; j'ai 2 fichier index.php et traitement.php
    index.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
    <script type="text/javascript">
    		$(document).ready(function(){
    			$("#charger").click(function(){
    				var fil =$("#filiere").val();
    				var sem=$("#semestre").val();
    				$("#mod").empty();
    				$("#mod").append('<option value="">Choisir une matière</option>');
    				$.ajax({
    					url: 'traitement.php',
    					data: 'f=' + fil + '&s=' + sem,
    					dataType: 'json', // on veut un retour JSON
    					success: function(json) {
    						$.each(json, function(index, value) {
    						// pour chaque noeud JSON
    						// on ajoute l option dans la liste
    							$("#mod").append('<option value="'+ index +'">'+ value +'</option>');
    						});
    					}
    				});
    				//data : 'email=' + email + '&contenu=' + contenu_mail, 
    			});
    		});
    </script>
    j'ai pas inclue la partie formulaire; mais il y a aucun problème à ce niveau
    traitement.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
    <?php
    	try {
    		$bdd = new PDO('mysql:host=localhost;dbname=test', 'root', '');
    	} catch(Exception $e) {
    		exit('Impossible de se connecter à la base de données.');
    	}
     
    	$json = array();
     
    	if(isset($_GET['f']) && isset($_GET['s'])) {
    		// requête qui récupère les localités un
    		$requete = "SELECT matiere FROM table1 WHERE filiere= '".$_GET['f']."' AND semestre ='".$_GET['s']."' GROUP BY matiere ORDER BY id";
    		// exécution de la requête
    		$resultat = $bdd->query($requete) or die(print_r($bdd->errorInfo()));
    		// Création de la liste
    		while($donnees = $resultat->fetch(PDO::FETCH_ASSOC)) {
    			// je remplis un tableau et mettant l'id en index
    			$json[$donnees["module"]][] = utf8_encode($donnees["module"]);
    		}
    	//}
    	 // envoi du résultat au success
    	echo json_encode($json);
    	}
    ?>
    le problème est le suivant:
    Lorsque je clique sur le lien qui lance le traitement (lien dont l'id est "charger") et que je choisi successivement "MG" comme filière et "1" comme semestre...j'obtiendrai le résultat avec succès mais si je change le semestre en "2"; j'obtiendrai rien (que la première oprion par defaut: "Choisir une matière").
    voici une capture de la tabble MYSQL:
    Nom : table.png
Affichages : 1101
Taille : 25,3 Ko.
    Merci d'avance de m'aider

  2. #2
    Expert confirmé Avatar de Toufik83
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Janvier 2012
    Messages
    2 511
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : Maroc

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

    Informations forums :
    Inscription : Janvier 2012
    Messages : 2 511
    Par défaut
    je pense qu'il te faut enlever les '' dans ta requête, c'est à dire faire ça
    Code PHP : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    ... where semestre =".$_GET['s']."...

  3. #3
    Membre confirmé
    Inscrit en
    Mai 2010
    Messages
    128
    Détails du profil
    Informations forums :
    Inscription : Mai 2010
    Messages : 128
    Par défaut
    Bonsoir Toufik83;
    j'ai apporté la modification au niveau de la requête mais toujours le même problème.
    je tiens à vous informer que le résultat est parfait lorsque je choisi "1" dans le combo semestre !!!
    je tiens à vous informer aussi que si j’exécute ma requête sur PHPMYADMIN, elle retourne bien les résultats avec succès soit avec "1" ou "2" comme semestre.
    Merci

Discussions similaires

  1. [Python 3.X] Utiliser contenu d'une bdd pour remplir une liste déroulante.
    Par djbryan94 dans le forum GUI
    Réponses: 2
    Dernier message: 04/03/2015, 08h03
  2. [Plugin] [jqGrid] Remplir une liste déroulante par AJAX ?
    Par Odawin dans le forum jQuery
    Réponses: 3
    Dernier message: 10/03/2014, 20h33
  3. Réponses: 1
    Dernier message: 29/06/2013, 18h26
  4. [AJAX] Remplir une liste déroulante avec la réponse du réquête d'Ajax
    Par duppp2000 dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 05/12/2007, 16h28
  5. [débutant] Remplir une liste déroulante
    Par Floch dans le forum Général JavaScript
    Réponses: 7
    Dernier message: 12/05/2006, 13h39

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