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 :

menu déroulant dynamique


Sujet :

JavaScript

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    139
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 139
    Points : 66
    Points
    66
    Par défaut menu déroulant dynamique
    Bonsoir,

    j'ai réalisé un script afin de réaliser un système de choix entre 3 menus déroulants et je n'arrive pas à obtenir le résultat escompté. Je m'explique:
    J'ai 3 menus déroulants dons les valeurs vont de 1 à x (dans mon exemple 1 à 3) Au départ, la sélection est la suivante:
    1
    2
    3
    Je souhaite pouvoir changé le 1 en 2 et qu'en même temps, le 2 devienne 1. Mais je n'y arrive pas
    Si quelqu'un pouvait m'aider, ce serait super.
    Merci par avance.
    Je vous joins mon bout de code ci dessous:

    Code html : 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
     
    <body>
     <form name="choix">
    <select name="place" onchange="rang()"size=1>
    <option value="1" selected="selected">1</option>
    <option value="2">2</option>
    <option value="3">3</option>
          </select>
      </form> 
        <form name="choix2">
    <select name="place" onchange="rang()"size=1>
    <option value="1">1</option>
    <option value="2" selected="selected">2</option>
    <option value="3">3</option>
          </select>
      </form>     
     <form name="choix3">
    <select name="place" onchange="rang()"size=1>
    <option value="1">1</option>
    <option value="2">2</option>
    <option value="3" selected="selected">3</option>
          </select>
    </form>       
    </body>

  2. #2
    Membre du Club
    Profil pro
    Inscrit en
    Mars 2009
    Messages
    139
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2009
    Messages : 139
    Points : 66
    Points
    66
    Par défaut
    Voici le script que l'on m'a transmis sur un autre fofo. J'en profite pour vous en faire part.

    <body>
    <form name="choix">
    <select name="place" onchange="rang(0)"size=1>
    <option value="1" selected="selected">1</option>
    <option value="2">2</option>
    <option value="3">3</option>
    </select>
    </form>
    <form name="choix2">
    <select name="place" onchange="rang(1)"size=1>
    <option value="1">1</option>
    <option value="2" selected="selected">2</option>
    <option value="3">3</option>
    </select>
    </form>
    <form name="choix3">
    <select name="place" onchange="rang(2)"size=1>
    <option value="1">1</option>
    <option value="2">2</option>
    <option value="3" selected="selected">3</option>
    </select>
    </form>
    <script type="text/javascript">
    var sel; // Variable pour récupérer tous les <select>
    var valeurs = []; // Tableau pour garder en mémoire les valeurs
    function rang(nb) { // En paramètre l'indice du <select>
    var val = sel[nb].value; // On garde dans "val" la valeur du <select> modifié
    for(var i=0,l=sel.length;i<l;i++) { // On parcourt la totalité des <select>
    if((i!=nb) && (sel[i].value == val)) { // Si ce n'est pas le <select> modifié et que la valeur correspond
    sel[i].value = valeurs[nb]; // On lui applique l'ancienne valeur de <select> modifié
    valeurs[i] = valeurs[nb]; // Et on enregistre le changement dans le tableau des valeurs
    }
    }
    valeurs[nb] = val; // On enregistre également le changement du <select> modifié
    }
    window.onload=function() { // Au chargement (initialisation)
    sel = document.getElementsByTagName("select"); // On récupère tous les éléments <select> dans "sel"
    for(var i=0,l=sel.length;i<l;i++) { // On parcourt tout
    valeurs.push(sel[i].value); // Et on sauvegarde les valeurs dans le tableau "valeurs".
    }
    }
    </script>
    </body>

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

Discussions similaires

  1. Réponses: 10
    Dernier message: 22/03/2007, 08h36
  2. [MySQL] menu déroulant dynamique
    Par heteroclite dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 25/10/2006, 20h16
  3. menu déroulant dynamique
    Par jojo971 dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 22/06/2006, 14h43
  4. [Conception] Menu déroulant dynamique et administrable
    Par guy2004 dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 16/05/2006, 15h37

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