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

Langage PHP Discussion :

php / JS / Jquery + JCombo


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    149
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 149
    Points : 65
    Points
    65
    Par défaut php / JS / Jquery + JCombo
    Bonjour,

    Je débute en php/JS et j'essaie de réaliser deux select imbriqués (menu deroulant). J'utilise pour cela jQuery + JCombo.

    Cela marche pour le premier menu deroulant mais rien pour le 2e.
    Après plusieurs tests, il semble que le problème soit au niveau du passage/récupération par $_GET.


    Mon HTML > OK a priori
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    		Fournisseur : <select id="fournisseur"></select> <br/><br/>
    		Article : <select id="article"></select> <br/><br/>
     
    		<script type="text/javascript">
    		$("#fournisseur").jCombo("formE_GetFournisseur.php", {
    			initial_text: "-- Choisir un fournisseur --" // initial option
    		} );
     
    		$("#article").jCombo("formE_GetArticle.php?id=", { 
    			parent: "#fournisseur",
    			initial_text: "-- Choisir un article --" // initial option
    		} );
    		</script>

    formE_GetFournisseur.php > OK
    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
     
    <?php
    include("fonctions.php");
     
    	ConnectMaBase();
    		$sql = 'SELECT DISTINCT fournisseur FROM articles ORDER BY fournisseur LIMIT 0,99';
     
    		$req = mysql_query($sql) or die('Erreur SQL !<br />'.$sql.'<br />'.mysql_error());
    		$items = array();
    		if($req && mysql_num_rows($req)>0) {
    			while($row = mysql_fetch_array($req)) {
    				$items[] = array( $row[0], $row[0] );
    			}        
    		}
    		mysql_free_result ($req);
    	mysql_close();
     
    	echo json_encode($items); 
    ?>

    formE_GetArticle.php > KO

    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
     
    <?php
    include("fonctions.php");
     
    	ConnectMaBase();
     
    		$fournisseur = $_GET['id'];
     
    		$sql = 'SELECT nom FROM articles WHERE fournisseur = ".'$fournisseur'." ORDER BY nom LIMIT 0,99';
     
    		$req = mysql_query($sql) or die('Erreur SQL !<br />'.$sql.'<br />'.mysql_error());
    		$items = array();
    		if($req && mysql_num_rows($req)>0) {
    			while($row = mysql_fetch_array($req)) {
    				$items[] = array( $row[0], $row[0] );
    			}        
    		}
    		mysql_free_result ($req);
    	mysql_close();
     
    	echo json_encode($items); 
    ?>
    Une belle fonction contient au plus 7 lignes de code,
    Une belle procédure appelle au plus 7 fonctions,
    Un beau programme est lisible et compréhensible,
    Dans tous les autres cas, une optimisation s'impose.

  2. #2
    Modérateur

    Avatar de NoSmoking
    Homme Profil pro
    Inscrit en
    Janvier 2011
    Messages
    16 959
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations forums :
    Inscription : Janvier 2011
    Messages : 16 959
    Points : 44 122
    Points
    44 122
    Par défaut
    Bonsoir,
    Après plusieurs tests, il semble que le problème soit au niveau du passage/récupération par $_GET.
    il ne s'agirait donc pas d'un problème de javascript mais de PHP & SGBD!

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    149
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 149
    Points : 65
    Points
    65
    Par défaut
    à moins que cela vienne d'un bug dans le plugin JCombo ?
    ou problème de compatibilité avec JQuery v1.8.1 ?
    Une belle fonction contient au plus 7 lignes de code,
    Une belle procédure appelle au plus 7 fonctions,
    Un beau programme est lisible et compréhensible,
    Dans tous les autres cas, une optimisation s'impose.

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    149
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 149
    Points : 65
    Points
    65
    Par défaut
    Si je laisse ce code c'est KO :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    	$fournisseur = 'TOTO';
    	$sql = 'SELECT nom FROM articles WHERE fournisseur=".'$fournisseur'." ORDER BY nom LIMIT 0,99';
    si je remplace par ce code c'est OK :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
    	$sql = 'SELECT nom FROM articles WHERE fournisseur="TOTO" ORDER BY nom LIMIT 0,99';
    Une belle fonction contient au plus 7 lignes de code,
    Une belle procédure appelle au plus 7 fonctions,
    Un beau programme est lisible et compréhensible,
    Dans tous les autres cas, une optimisation s'impose.

  5. #5
    Membre confirmé
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Avril 2011
    Messages
    271
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Italie

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2011
    Messages : 271
    Points : 491
    Points
    491
    Par défaut
    Tu devrais l'écrire comme ca
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $fournisseur = "TOTO";
    	$sql = "SELECT nom FROM articles WHERE fournisseur='$fournisseur' ORDER BY nom LIMIT 0,99";

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Juillet 2003
    Messages
    149
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2003
    Messages : 149
    Points : 65
    Points
    65
    Par défaut
    Cela semble OK, merci.
    Une belle fonction contient au plus 7 lignes de code,
    Une belle procédure appelle au plus 7 fonctions,
    Un beau programme est lisible et compréhensible,
    Dans tous les autres cas, une optimisation s'impose.

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

Discussions similaires

  1. Intégration PHP et jquery week calendar?
    Par Sayrus dans le forum Langage
    Réponses: 8
    Dernier message: 22/10/2009, 15h25
  2. php et jquery récupérer un $_POST
    Par elcastor dans le forum jQuery
    Réponses: 1
    Dernier message: 06/06/2009, 17h46
  3. Moteur de recherche PHP - Ajax - Jquery - SQL
    Par visual3d dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 1
    Dernier message: 20/05/2009, 15h45
  4. [JQUERY] Comment appeler une fonction php avec jquery
    Par popogendarme dans le forum jQuery
    Réponses: 1
    Dernier message: 20/03/2007, 16h07

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