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 :

renseigner un champs texte d'apres un select


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre averti
    Inscrit en
    Février 2009
    Messages
    35
    Détails du profil
    Informations forums :
    Inscription : Février 2009
    Messages : 35
    Par défaut renseigner un champs texte d'apres un select
    bjr jai un probleme dans un code javascript voila la question:Ecrivez un script javascript comprenant une liste déroulante et un champs de texte. La liste
    déroulante sera composée de nom de pays. Quand on sélectionnera un pays de la liste, la capitale s’affichera dans le champs de texte
    .et voila le code que j'ai mi mais ça donne rien et je comprend pa pourquoi .svp aidez moi et merci d'avance.
    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
    <html>
    <head>
    <title>Test</title>
    <script language="javascript" type="text/javascript">
    <!--
    function capitale(form1){
    if (form1.list.(selectedIndex+1)=1);
    form1.txtCapitale.value="Rabat";
    else
    if (form1.list.(selectedIndex+1)=2);
    form1.txtCapitale.value="Paris";
    else
    if (form1.list.selectedIndex(selectedIndex+1)=3);
    form1.txtCapitale.value="Rome";
    else
    if (form1.list.selectedIndex(selectedIndex+1)=4);
    form1.txtCapitale.value="Madrid";
    }
    //-->
    </script>
    </head>
    <body>
     <form name="form1">
      <select name="list" onchange="capitale(form1)">
      <option value="1">Maroc</option>
      <option value="2">France</option>
      <option value="3">Italie</option>
      <option value="4">Espagne</option>
      </select>
      <br>
      <input type="text" name="txtCapitale">
     
     </form>
     
     </body>
     
    </html>

  2. #2
    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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    Le switch est tout a fait indiqué pour ces cas de figure
    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
    <html>
    <head>
    <title>Test</title>
    <script language="javascript" type="text/javascript">
    <!--
    function capitale(sel){
    var capitale=""
    switch (sel) {
     case "1" : capitale= "Rabat"
                break;
     case "2" : capitale= "Paris"
                break;
     case "3" : capitale= "Rome"
                break;
     case "4" : capitale= "Madrid"
                break;
     default:   capital="";}
     document.getElementsByName("txtCapitale")[0].value=capitale;}
     
     
     
     
    //-->
    </script>
    </head>
    <body>
     <form name="form1">
      <select name="list" onchange="capitale(this.value)">
      <option value="-1">selectionnez le pays</option>
      <option value="1">Maroc</option>
      <option value="2">France</option>
      <option value="3">Italie</option>
      <option value="4">Espagne</option>
      </select>
      <br>
      <input type="text" name="txtCapitale">
     
     </form>
     
     </body>
     
    </html>
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

  3. #3
    Membre chevronné
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    313
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 313
    Par défaut
    A ce stade, un tableau (associatif ou non) serait aussi bien :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    function capitale(sel) {
    if (sel < 0) return;
    var caps = ['',"Rabat","Paris","Rome","Madrid"];
    document.getElementsByName("txtCapitale")[0].value=caps[parseInt(sel)]
    }
    Pour les values :
    Pourquoi ne pas avoir commencé à 'zéro' ?
    Pourquoi ne pas mettre directement le nom des capitales en value des options ?

  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 : 54
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Billets dans le blog
    20
    Par défaut
    Mouais... il y a plus simple selon moi :
    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
    <html>
    <head>
    <title>Test</title>
    <script language="javascript" type="text/javascript">
    <!--
    function capitale(valeur){
    document.getElementById('resultat').value = valeur == '0' ? '' : valeur;
    }
    //-->
    </script>
    </head>
    <body>
     <form name="form1">
      <select name="list" onchange="capitale(this.value)">
      <option value="0">Voir la capitale</option>
      <option value="Rabat">Maroc</option>
      <option value="Paris">France</option>
      <option value="Rome">Italie</option>
      <option value="Madrid">Espagne</option>
      </select>
      <br>
      <input type="text" name="txtCapitale" id="resultat" />
     
     </form>
     
     </body>
     
    </html>
    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
    Membre chevronné
    Profil pro
    Inscrit en
    Juin 2009
    Messages
    313
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juin 2009
    Messages : 313
    Par défaut
    Bah oui.
    Et mettre le code direct dans le onchange tant qu'à faire

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    <select name="list" onchange="document.getElementById('resultat').value = this.value">
    <option value="">Voir la capitale</option>
    <option value="Rabat">Maroc</option>
    etc...

  6. #6
    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 659
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 75
    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 659
    Billets dans le blog
    1
    Par défaut
    je préfère toute fois rester sur le switch principalement pour deux raisons:
    * on peut avoir besoin du value pour autre chose et donc ça le monopolise avec le nom de la capitale
    * je trouve et ce n'est qu'un avis personnel plus facile de mettre à jour un switch qu'un array dans la version array


    sinon niveau optimisation il est clair que ce n'est pas la meilleure solution. Je suis dans l'optique maintenance.
    Ma page Developpez - Mon Blog Developpez
    Président du CCMPTP (Comité Contre le Mot "Problème" dans les Titres de Posts)
    Deux règles du succès: 1) Ne communiquez jamais à quelqu'un tout votre savoir...
    Votre post est résolu ? Alors n'oubliez pas le Tag

    Venez sur le Chat de Développez !

Discussions similaires

  1. Réponses: 2
    Dernier message: 10/01/2012, 15h20
  2. Renseigner le champ "légende" d'après une table
    Par stsym dans le forum VBA Access
    Réponses: 8
    Dernier message: 21/03/2011, 10h08
  3. Réponses: 10
    Dernier message: 04/06/2008, 14h30
  4. Réponses: 9
    Dernier message: 09/01/2007, 11h06
  5. Réponses: 4
    Dernier message: 07/11/2006, 23h00

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