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 :

Passer les valeurs d'une liste multiselection a une fonction javascript/Ajax?


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 37
    Points : 28
    Points
    28
    Par défaut Passer les valeurs d'une liste multiselection a une fonction javascript/Ajax?
    Bonjour,
    Je vous explique mon probleme:
    J'ai une liste de multiselection html et j'aimerais la traité dynamiquement pour en remplir une autre.
    Déjà, est ce possible? ensuite si oui, je pe vous mointrer le code que j'ai pour essayé de le realisé.
    Mon probleme c'est que ca ne prend que la premier valeur selectionné et pas les autre, ca parait logique mais j'aimerais bien trouv" un moyen pour detourné ca..
    Voici mon code :

    Fonction javascript (ajax) :
    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
     
    	function recherche2(sfam)
    	{
    		if(sfam!=''){
    			var xhr;
    			if (window.XMLHttpRequest) { 
    				xhr = new XMLHttpRequest();
    			}
    			else if (window.ActiveXObject) 			{
    				xhr = new ActiveXObject("Microsoft.XMLHTTP");
    			}
    			xhr.onreadystatechange = function(){
     
    				if(xhr.readyState == 4){
    					document.getElementById('blockdaffichage2').innerHTML = xhr.responseText;
    				}
    			};
    			xhr.open("GET", "formulaire/requete2.php?entree="+sfam+"", true);
    			xhr.send(null);
    		}
    	}
    Fichier Creation.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
     
    <select name="sfam[]"  id="sfam" multiple size='4' >
           			<?php
                                    $sfam = new sousfamille();
                                    $sousFam = $sfam->NomSousFamilles();
                                    while($v = mysql_fetch_array($sousFam)) 
                                            {
                                                    ?>
      							<option value="<?php echo utf8_encode($v['nomsf']); ?>" <?php if ($_SESSION['sfam'] == (utf8_encode($v['nomsf']))) echo "selected";?>><?php echo utf8_encode($v["nomsf"]); ?> </option>
     
      						<?php
                                            }
                            ?>
    	        </select>
    	        <span class="red">*</span>
    	        <a href="formulaire/addsousFam.php" onclick="window.open(this.href, 'H', 'width=400, height=150'); return false;">
    			Ajouter une sous-famille</a>
     
    			<br/>
    			<a href="#" onclick="recherche2(sfam.value);" > Afficher les motifs des sous-familles s&eacute;l&eacute;ctionn&eacute;es </a>
    			<br/>
    			<br/>
     
     
    			Motif: <font size='1'>(Ctrl+clic gauche pour multiselection)</font>
    			<span id="blockdaffichage2">
                            </span>
    et enfin :
    requete2.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
     
    $entree = $_GET["entree"];
     
    $mot = new motif();
    $requete = $mot->search($entree);
     
    ?>
     
     
    <select name="mot[]" multiple size="4">
    <option value="">Choisissez le motif</option>
    <?php 
     
    if(mysql_num_rows($requete)>=1)
    {
            while($v = mysql_fetch_array($requete)) 
            {
                    ?>
      		<option value= "<?php echo utf8_encode($v["nommot"]);?>"> <?php echo utf8_encode($v['nommot']); ?> </option>	  			
    		<?php
            }
    }
    else
    {
            ?><option value="">Il n'y a aucun motif pour la sous-famille <?php echo " ".utf8_encode($entree); ?> </option> <?php
    }
            
            ?>
    </select>
    Bon apré faut que je traite $entree comme un tableau mais ca ya pas de pb.

    Voila, si vous voulez des precisions hesiter pas a me demander.
    Merci d'avance.
    J'espere avoir etait clair sur ce que je voulais.

  2. #2
    Membre expérimenté Avatar de julien.63
    Profil pro
    balayeur
    Inscrit en
    Décembre 2005
    Messages
    1 348
    Détails du profil
    Informations personnelles :
    Localisation : France, Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : balayeur

    Informations forums :
    Inscription : Décembre 2005
    Messages : 1 348
    Points : 1 311
    Points
    1 311
    Par défaut
    salut
    oui c'est possible de récupérer plusieurs valeurs sélectionnées dans ton select.
    exemple :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    function getValue(){
    	var value = new Array();
    	var select = document.getElementById('selectField');
    	for (i=0;i<select.childNodes.length;i++){
    		if (select.childNodes[i].selected){
    			value.push(select.childNodes[i].value);
    		}	
    	}
    	alert(value);
    }
    je mets un alert tout bête à la fin de la fonction mais toi tu peux retourner une chaine de caractère pour l'envoyer via ta requête ajax

  3. #3
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    se mefier des ChildNodes

    mieux vaut scanner les obj.options[i] pour savoir lesquelles sont sélectionnées ...

  4. #4
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 37
    Points : 28
    Points
    28
    Par défaut
    Merci mais pour envoyé tout ca a ma fonction ajax je fais comment?

    return recherche2(value);

    a la place du alert(value)?

  5. #5
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 665
    Points
    66 665
    Billets dans le blog
    1
    Par défaut
    tu veux le faire en get ou en post ?

    au lieu de concaténer ton lien ...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    xhr.open("GET", "formulaire/requete2.php?entree="+sfam+"", true);
    regarde du coté de xhr.send ...

  6. #6
    Membre expérimenté Avatar de julien.63
    Profil pro
    balayeur
    Inscrit en
    Décembre 2005
    Messages
    1 348
    Détails du profil
    Informations personnelles :
    Localisation : France, Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : balayeur

    Informations forums :
    Inscription : Décembre 2005
    Messages : 1 348
    Points : 1 311
    Points
    1 311
    Par défaut
    se mefier des ChildNodes
    spacefrog : je ne suis pas expert en javascript et j'en profite pour faire une digression. Pourquoi l'usage des childNodes n'est-il pas recommandé?

  7. #7
    Rédacteur/Modérateur

    Avatar de SpaceFrog
    Homme Profil pro
    Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Inscrit en
    Mars 2002
    Messages
    39 640
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 74
    Localisation : Royaume-Uni

    Informations professionnelles :
    Activité : Développeur Web Php Mysql Html Javascript CSS Apache - Intégrateur - Bidouilleur SharePoint
    Secteur : Industrie

    Informations forums :
    Inscription : Mars 2002
    Messages : 39 640
    Points : 66 665
    Points
    66 665
    Billets dans le blog
    1

  8. #8
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 37
    Points : 28
    Points
    28
    Par défaut
    J'ai compris le principe du getValue() mais je n'arrive pas à passer le tout à ma fonction AJAX pour pouvoir traiter le tableau comme je veux... j'ai essayé de plusieurs manière mais je vois pas comment faire...

  9. #9
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Octobre 2006
    Messages
    37
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Octobre 2006
    Messages : 37
    Points : 28
    Points
    28
    Par défaut
    C'est bon merci beaucoup pour votre aide.
    Je suis finalement passez par unn bouton avec en onClick le getValue qui recupere les choix selectionné de ma liste et qui appel a la fin la fonction ajax.
    Ca marche nickel !

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

Discussions similaires

  1. Réponses: 3
    Dernier message: 12/09/2012, 23h48
  2. [AJAX] liste liée a une liste liée a une liste
    Par dirty_harry dans le forum AJAX
    Réponses: 2
    Dernier message: 03/07/2009, 11h18
  3. acceder à une liste contenue dans une liste
    Par CPI_en_mousse dans le forum Servlets/JSP
    Réponses: 14
    Dernier message: 12/06/2007, 08h33
  4. [SQL] recupere les valeurs d'un liste puis faire une requete SQL
    Par 18Marie dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 22/06/2006, 12h50
  5. remplir une liste à partir d'une liste
    Par LeXo dans le forum Access
    Réponses: 7
    Dernier message: 14/04/2006, 12h29

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