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 :

Dans un select option onChange()


Sujet :

JavaScript

  1. #1
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Août 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2014
    Messages : 13
    Points : 8
    Points
    8
    Par défaut Dans un select option onChange()
    Bonjour!

    Encore novice en php et java script, j'ai quelques problème avec des liste déroulante liées.

    Je m'explique J'ai 2 liste déroulantes.

    La premiere afficher la liste des services
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    <td nowrap class="Libelle" align="left"><?php   $mess->printString("poste.service") ?> : </td>
    <td>                                          
        <select name="service" size="1" class="Controle_Plat_Obligatoire_EA" OnChange="change_service()">
    	<option value="0">Sélectionnez le service ...
    <?php for ($i = 0 ; $i < sizeof($service_datas) ; $i++)    {?>                                            
           <option value="<?php  echo $service_datas[$i][BU_CODE]?>"><?php  echo $service_datas[$i][BU_LIB]?>
    <?php } ?>
        </select>
    </td>
    pas de probléme sur celle-ci

    La seconde affiche normalement les sous services Niveau
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <td nowrap class="Libelle" align="left"><?php   $mess->printString("user.poste"); ?> : </td>
    <td>                                          
        <select name="service_niveau1" size="1" class="Controle_Plat_Obligatoire_EA">
    <?php if ($hierarchie_1_datas[0][hierachie_CODE] == 0 ) { ?><option value="0" <?php   if ($_POST[bu]) echo "selected"?>>Sélectionnez la fonction ...<?php   } ?>
    <?php if ($hierarchie_1_datas[0][hierachie_CODE] <> 0 ) { ?><option value="0" >Service Niveau 1 ...<?php   } ?>                                    
    <?php for ($i = 0 ; $i < sizeof($hierarchie_1_datas) ; $i++)    {?>                                            
            <option value="<?php  echo $hierarchie_1_datas[$i][hierarchie_CODE]?>"<?php  if ($datas[0][hierarchie] == $hierarchie_1_datas[$i][hierarchie_CODE]) echo "selected"?>><?php  echo $hierarchie_1_datas[$i][hierarchie_LIBELLE]?>
    <?php }	?>
        </select>
    </td>


    En gros problème, je voudrai arriver à mettre à jour la liste déroulante sous service (sans changer de page qu'elle se réactuliser automatiquement) en utilisant l'option onChange(), mais ça a pas l'air de vouloir :'(

    fonction actuel dans le onChange()

    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
    <script>
    function change_service() {
    	var code_act = document.Frm_MAJPoste.service.value;
       //         	 Liste des hôtels
    	var indice = 1;
    	document.Frm_MAJPoste.service_niveau1.options[0].value ="0";
    	document.Frm_MAJPoste.service_niveau1.options[0].text = "Sélectionnez le service niveau 1 ..."
    <?php    for ($i=0; $i< sizeof($hierarchie_1_datas); $i++) { ?> 
    	var code_act_fil = "<?php    echo $hierarchie_1_datas[$i][HIERARCHIE_SERVICE] ?>";
    	if (code_act == "" || code_act_fil == code_act) {
    		document.Frm_MAJPoste.service_niveau1.length = indice + 1;  
    		document.Frm_MAJPoste.service_niveau1.options[indice].value="<?php    echo $hierarchie_1_datas[$i][hierarchie_CODE] ?>";
    		document.Frm_MAJPoste.service_niveau1.options[indice].text="<?php    echo $hierarchie_1_datas[$i][hierarchie_LIBELLE] ?>";   
    		indice = indice + 1;
    	}
    <?php    } ?>
    	document.Frm_MAJPoste.service_niveau1.length = indice;
    }
    </script>
    Pour le moment cette fonction fonctionne jusqu'a "document.Frm_MAJPoste.service_niveau1.options[0].text = "Sélectionnez le service niveau 1 ...""

    Fonction pour recupére dans la table THierarchie les sous services.

    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    Function Datas_hierarchie_1($COOKIE) {
            $datas = Array();
            $bd = new BaseMysql;
            $requete="SELECT thierarchie_departement.* FROM thierarchie_departement";
            $requete.= "  WHERE hierarchie_SITE = ".$COOKIE[cookie_user_site]; 
    	$requete.= "  AND hierarchie_NIVEAU = 1";
            $requete.="   ORDER BY hierarchie_LIBELLE";
    //        echo "<BR>$requete<BR>";        
            return($bd->get_all_values($requete));
          }

    Est ce que quelqu'un pourrais me donner un petit coup de pouce svp :-)
    Merci

  2. #2
    Membre expert
    Avatar de Dendrite
    Femme Profil pro
    Développeuse informatique
    Inscrit en
    Juin 2008
    Messages
    2 129
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 58
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeuse informatique
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Juin 2008
    Messages : 2 129
    Points : 3 627
    Points
    3 627
    Billets dans le blog
    8
    Par défaut
    1) Mets ton code dans une balise code... Indente proprement.
    2) Ton problème est un problème javascript, pas PHP. Tu n'es pas dans le bon forum.
    PDO, une soupe et au lit !
    Partir de la fin est un bon moyen de retrouver son chemin. Bibi - 2020

  3. #3
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Août 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2014
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    Bjr
    vu que ya un peu des deux je savais pas trop ou le mettre.

    Premiere liste déroulante "service"
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    <td nowrap class="Libelle" align="left"><?php $mess->printString("poste.service") ?> : </td>
    <td> 
    <select name="service" size="1" class="Controle_Plat_Obligatoire_EA" OnChange="change_service()">
    <option value="0">Sélectionnez le service ...
    <?php for ($i = 0 ; $i < sizeof($service_datas) ; $i++) {?> 
    <option value="<?php echo $service_datas[$i][BU_CODE]?>"><?php echo $service_datas[$i][BU_LIB]?>
    <?php } ?>
    </select>
    </td>
    Deuxieme liste déroulante "sous service" (niveau1)
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <td nowrap class="Libelle" align="left"><?php   $mess->printString("user.poste"); ?> : </td>
                                             	<td>                                          
                                                 	<select name="service_niveau1" size="1" class="Controle_Plat_Obligatoire_EA">
    <?php                                                   if ($hierarchie_1_datas[0][hierachie_CODE] == 0 ) { ?><option value="0" <?php   if ($_POST[bu]) echo "selected"?>>Sélectionnez la fonction ...<?php   } ?>
    <?php                                                   if ($hierarchie_1_datas[0][hierachie_CODE] <> 0 ) { ?><option value="0" >Service Niveau 1 ...<?php   } ?>                                    
    <?php                                                   for ($i = 0 ; $i < sizeof($hierarchie_1_datas) ; $i++)    {?>                                            
                                                            	<option value="<?php  echo $hierarchie_1_datas[$i][hierarchie_CODE]?>"<?php  if ($datas[0][hierarchie] == $hierarchie_1_datas[$i][hierarchie_CODE]) echo "selected"?>><?php  echo $hierarchie_1_datas[$i][hierarchie_LIBELLE]?>
    <?php                                                   }       ?>
                                                 	</select>
                                             	</td>
    la fonction dans le ONCHANGE()
    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
    <script>
    function change_service() {
     
     
    		var code_act = document.Frm_MAJPoste.service.value;
     
     
       //         	 Liste des hôtels
     
             	var indice = 1;
             	document.Frm_MAJPoste.service_niveau1.options[0].value ="0";
             	document.Frm_MAJPoste.service_niveau1.options[0].text = "Sélectionnez le service niveau 1 ..."
     
    		<?php    for ($i=0; $i< sizeof($hierarchie_1_datas); $i++) { ?> 
     
     
             		var code_act_fil = "<?php    echo $hierarchie_1_datas[$i][HIERARCHIE_SERVICE] ?>";
     
    			if (code_act == "" || code_act_fil == code_act) {
             			document.Frm_MAJPoste.service_niveau1.length = indice + 1;  
          		   		document.Frm_MAJPoste.service_niveau1.options[indice].value="<?php    echo $hierarchie_1_datas[$i][hierarchie_CODE] ?>";
    				document.Frm_MAJPoste.service_niveau1.options[indice].text="<?php    echo $hierarchie_1_datas[$i][hierarchie_LIBELLE] ?>";   
             			indice = indice + 1;
     
             		}
             	<?php    } ?>
     
             	document.Frm_MAJPoste.service_niveau1.length = indice;
     
          }
     
     
    </script>
    Fonction pour recupére dans la table THierarchie les sous services.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    Function Datas_hierarchie_1($COOKIE) {
     
            $datas = Array();
            $bd = new BaseMysql;
     
            $requete="SELECT thierachie_departement.* FROM thierachie_departement";
            $requete.= "  WHERE hierachie_SITE = ".$COOKIE[cookie_user_site]; 
    	$requete.= "  AND hierachie_NIVEAU = 1";
            $requete.="   ORDER BY hierachie_LIBELLE";
     
    //        echo "<BR>$requete<BR>";        
            return($bd->get_all_values($requete));
          }

  4. #4
    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 : 53
    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 418
    Points
    91 418
    Billets dans le blog
    20
    Par défaut
    Le code JavaScript que tu génères est complètement incohérent...
    Tu crées du code répétitif dans une boucle PHP et dans ces portions de code répétées, tu inities des variables. Bref, chaque variable définie dans une itération va écraser le code des itérations précédentes...
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, 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
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  5. #5
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Août 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2014
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    oula carement daccord je vois ce que tu veut dire

    est ce que tu peu quand même m'aider s'il te plait
    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
     
    <script>
    function change_service() {
     
     
    		var code_act = document.Frm_MAJPoste.service.value; //<-- ici je recupere le code service que j'ai selection dans la premiere liste déroulante
            	             var indice = 1;
             	             document.Frm_MAJPoste.service_niveau1.options[0].value ="0";
             	             document.Frm_MAJPoste.service_niveau1.options[0].text = "Sélectionnez le service niveau 1 ..." //<-- ici ce qui s'affiche dans la deuxiéme liste déroulante a partir du moment au j'ai slectionné un service
     
    		<?php    for ($i=0; $i< sizeof($hierarchie_1_datas); $i++) { ?>  
     
             		var code_act_fil = "<?php    echo $hierarchie_1_datas[$i][HIERARCHIE_SERVICE] ?>"; //<-- le pb est la c sa ??? 
     
    			if (code_act == "" || code_act_fil == code_act) {
             			document.Frm_MAJPoste.service_niveau1.length = indice + 1;  
          		   		document.Frm_MAJPoste.service_niveau1.options[indice].value="<?php    echo $hierarchie_1_datas[$i][hierarchie_CODE] ?>";
    				document.Frm_MAJPoste.service_niveau1.options[indice].text="<?php    echo $hierarchie_1_datas[$i][hierarchie_LIBELLE] ?>";   
             			indice = indice + 1;
     
             		}
             	<?php    } ?>
     
             	document.Frm_MAJPoste.service_niveau1.length = indice;
     
          }
     
     
    </script>

  6. #6
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    encore une fois

    faites des pages html statiques
    avec des données statiques
    et des javascript statiques

    lorsque tout fonctionne il suffit de rendre les données dynamiques et uniquement les données.

    c'est une méthode simple efficace qui permet de tester à coup sur.
    et qui est économe en temps.

    A+JYT

  7. #7
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Août 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2014
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    Bonjour,
    j'ai essayé mais cela ne fonctionne pas
    comme je l'ai dit je suis novice en php et javascript
    pourtant j'ai l'impression que le code est correct

    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
    function change_service() {
    	var code_act = document.Frm_MAJPoste.service.value; //<-- ici je recupere le code service que j'ai selection dans la premiere liste déroulante
            var indice = 1;
            document.Frm_MAJPoste.service_niveau1.options[0].value ="0";
            document.Frm_MAJPoste.service_niveau1.options[0].text = "Sélectionnez le service niveau 1 ..." //<-- ici ce qui s'affiche dans la deuxiéme liste déroulante a partir du moment au j'ai slectionné un service
    <?php    for ($i=0; $i< sizeof($hierarchie_1_datas); $i++) { ?>  // <-- ici je recupere le nombre de ligne de ma requette 
    	var code_act_fil = "<?php    echo $hierarchie_1_datas[$i][HIERARCHIE_SERVICE] ?>"; //<-- ici je recupere la colonne service 
    	if ( code_act_fil == code_act) { //<-- ici les deux code services sont identique il m'afficher toute les lignes 
            	document.Frm_MAJPoste.service_niveau1.length = indice + 1;  
          		document.Frm_MAJPoste.service_niveau1.options[indice].value="<?php    echo $hierarchie_1_datas[$i][hierarchie_CODE] ?>";
    		document.Frm_MAJPoste.service_niveau1.options[indice].text="<?php    echo $hierarchie_1_datas[$i][hierarchie_LIBELLE] ?>";   
             	indice = indice + 1;
    	}
    <?php    } ?>
    	document.Frm_MAJPoste.service_niveau1.length = indice;
    }

  8. #8
    Expert éminent
    Avatar de sekaijin
    Homme Profil pro
    Urbaniste
    Inscrit en
    Juillet 2004
    Messages
    4 205
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Yvelines (Île de France)

    Informations professionnelles :
    Activité : Urbaniste
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2004
    Messages : 4 205
    Points : 9 127
    Points
    9 127
    Par défaut
    Je répète
    fais tout en satique sans php

    juste html css et javascript

    lorsque tu auras quelque chose de cohérent et fonctionnel
    tu pouras transformer ta page html en php

    A+JYT

  9. #9
    Futur Membre du Club
    Femme Profil pro
    Développeur informatique
    Inscrit en
    Août 2014
    Messages
    13
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Août 2014
    Messages : 13
    Points : 8
    Points
    8
    Par défaut
    J'ai réussi à faire fonctionner mon code
    je met la solution . Cela pourra peut être aider d'autres personnes.

    Merci pour les personnes qui ont répondu.

    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
     
    function change_service() {
     
    	var code_act = document.Frm_MAJPoste.service.value; 
     
                 var i = 1;
     
    	document.Frm_MAJPoste.service_niveau1.options[0].value ="0";
                 document.Frm_MAJPoste.service_niveau1.options[0].text = "Sélectionnez le service niveau 1 ...";
     
            	<?php      foreach ($hierarchie_3_datas as $hierarchie_3)  { ?> 
     
    		var service = "<?php echo $datas[0][POSTE_SERVICE] ?>";
     
    			 if (  code_act == service )
    				   {
     
                   				 document.Frm_MAJPoste.service_niveau1.length = i + 1;
                   				 document.Frm_MAJPoste.service_niveau1.options[i].value="<?php    echo $hierarchie_3[hierachie_CODE] ?>";
                  				 document.Frm_MAJPoste.service_niveau1.options[i].text="<?php    echo $hierarchie_3[hierachie_LIBELLE] ?>";
                  			 	 i = i + 1;
    				}
     
     
    	  <?php    } ?>	
     
    	document.Frm_MAJPoste.service_niveau1.length = i;
     
    	}

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

Discussions similaires

  1. [PHP 5.2] option onChange() dans un select
    Par Asphy dans le forum Langage
    Réponses: 7
    Dernier message: 27/06/2012, 14h55
  2. appeler une fonction js dans un select sur onChange
    Par laurentSc dans le forum Général JavaScript
    Réponses: 5
    Dernier message: 04/04/2011, 13h51
  3. [AJAX] test dans un select avec onchange
    Par stomerfull dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 16/01/2009, 16h08
  4. HTML dans un SELECT-OPTION
    Par keaton7 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 4
    Dernier message: 24/11/2008, 23h48
  5. insertion de saut de ligne dans un <select><option>
    Par Invité dans le forum Balisage (X)HTML et validation W3C
    Réponses: 6
    Dernier message: 01/08/2008, 10h49

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