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 :

Changer de liste dans une liste déroulante


Sujet :

JavaScript

  1. #1
    Membre éclairé
    Inscrit en
    Juin 2005
    Messages
    578
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 578
    Par défaut Changer de liste dans une liste déroulante
    Bonjour

    J'ai 2 listes déroulantes, la 1ère contient la liste des pays: Espagne, France, Italie et la 2e contient les villes : Barcelone,Madrid,Séville, Lille, Lyon, Paris, Milan,Rome.

    Je voudrais faire ceci: lorsque je clique par exemple sur Espagne, la liste de la 2e liste déroulante sera : Barcelone,Madrid,Séville; lorsque je clique sur France, la 2e liste déroulante sera Lille, Lyon, Paris...ainsi de suite.

    J'aimerais donc que ma 2e liste déroulante soit remplie en fonction du pays que j'ai choisi dans la 1ere liste déroulante.

    Le code que j'ai permet seulement de changer la valeur de la 2e liste déroulante et toute la liste:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    <script language="javascript">
                function changerVille() {
        var x = document.getElementById("pays").selectedIndex;
        var y = document.getElementById("pays").options;
        var z = y[x].value.lastIndexOf("-");
        document.getElementById(y[x].value.substr(z+1)).selected = "true";
      }
    </script>
    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
    <div class="styled-select">
        <select  id="pays" onchange="changerVille()">
            <option value="select">Sélectionnez un</option>
            <option value="Barcelone-Espagne">Doutchi</option>
            <option value="Lille-France">Lille</option>
            <option value="Rome-Italie">Rome</option>
        </select>
    </div>
    <div class="styled-select">
        <select  id="ville">                                                  
            <option id="Espagne" value="Espagne">Espagne</option>
            <option id="France" value="France">France</option>
            <option id="Italie" value="Italie">Italie</option>
        </select>
    </div>

    Merci

  2. #2
    Membre très actif
    Homme Profil pro
    bricoleur par les mots
    Inscrit en
    Avril 2015
    Messages
    744
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 80
    Localisation : France, Seine Maritime (Haute Normandie)

    Informations professionnelles :
    Activité : bricoleur par les mots
    Secteur : Distribution

    Informations forums :
    Inscription : Avril 2015
    Messages : 744
    Par défaut
    jour

    il y a contradiction entre ce qui doit ce faire et le code

    essai ceci


    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
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
     
    <!DOCTYPE html>
    <html lang="fr">
    <head>
    <meta charset="UTF-8">
     
    <script>
     
    var tb_pv={
     
    France:["Lille","Lyon","Paris"],
    Espagne:["Barcelone","Madrid","Séville"],
    Allemagne:["bone","berlin","munich"],
    Italie:["rome","turin","milan","venise"]
    }
     
    function changerVille(lui) {
     
    	var pays = lui.value;
     
    	document.getElementById("ville").innerHTML=''
     
    	for ( var i = 0 ; i < tb_pv[pays].length ; i++) {
     
    		var ville=tb_pv[pays][i]
     
    		var elem=document.createElement('option')
    		elem.setAttribute('value',ville)
     
    		var text = document.createTextNode(ville)
    		elem.appendChild(text)
     
    		document.getElementById('ville').appendChild(elem)
    	}
    }
    </script>
    </head>
    <body>
     
    <div class="styled-select">
    <select  onchange="changerVille(this)">  
     
    <option selected="selected" value="France">France</option>
    <option value="Espagne">Espagne</option>
    <option  value="Allemagne">Allemagne</option>
    <option  value="Italie">Italie</option>
     
    </select>
    </div>
     
    <br><br><br>
     
      <div class="styled-select">
    <select  id="ville">
     
    <option value="select">Sélectionnez un</option>
    <option value="Paris">Paris</option>
    <option value="Lille">Lille</option>
    <option value="Lyon">Lyon</option>
     
    </select>
    </div>
    </body>
    </html>

  3. #3
    Membre éclairé
    Inscrit en
    Juin 2005
    Messages
    578
    Détails du profil
    Informations forums :
    Inscription : Juin 2005
    Messages : 578
    Par défaut
    Merci beaucoup, ça marche.

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

Discussions similaires

  1. Une liste dans une liste
    Par Amadeus73 dans le forum Général Java
    Réponses: 4
    Dernier message: 04/08/2011, 19h19
  2. une liste dans une liste?
    Par JerryOne3 dans le forum C#
    Réponses: 11
    Dernier message: 11/01/2009, 16h43
  3. [débutant] Comment gérer une liste dans une liste
    Par Lenoiche dans le forum iReport
    Réponses: 0
    Dernier message: 16/07/2008, 10h41
  4. champ d'une liste lié à une liste dans un autre site
    Par guintolli dans le forum SharePoint
    Réponses: 8
    Dernier message: 08/07/2008, 14h51
  5. Appel d'une liste dans une liste (JSTL)
    Par abalgue dans le forum Hibernate
    Réponses: 4
    Dernier message: 15/06/2007, 10h56

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