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 :

Débuggage TypeError: document.forms.listes.elements[("liste" + i)] is undefined code.js:22


Sujet :

JavaScript

  1. #1
    Candidat au Club
    Homme Profil pro
    Thermicien
    Inscrit en
    Août 2015
    Messages
    4
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 52
    Localisation : France, Côtes d'Armor (Bretagne)

    Informations professionnelles :
    Activité : Thermicien
    Secteur : Administration - Collectivité locale

    Informations forums :
    Inscription : Août 2015
    Messages : 4
    Points : 3
    Points
    3
    Par défaut Débuggage TypeError: document.forms.listes.elements[("liste" + i)] is undefined code.js:22
    voila je ne vois pas ce qui cloche dans le code que j'ai recopié :

    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
    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
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    <!DOCTYPE HTML>
    <html>
        <head>
            <meta charset="UTF-8">
            <title>Quiz sur les pays</title>
            <link rel="stylesheet" media="screen" type="text/css" href="styles.css" type="text/css">
        </head>
        <body>
            <!-- titre -->
            <div id="titre"></div>
     
            <!-- liste déroulante -->
            <form id="listes" name="listes">
                <span id="numero1">1</span>
                <select name"liste1">
                    <option value=""></option>
                    <option value="Afghanistan">Afghanistant</option>
                    <option value="Azerbaïdjan">Azerbaïdjan</option>
                    <option value="kirghizistan">Kirghizistan</option>
                    <option value="Pakistan">Pakistan</option>
                    <option value="Tadjikistan">Tadjikistan</option>
                    <option value="Turkménistan">Turkménistan</option>
                    <option value="Ouzbékistan">Ouzbékistan</option>
                </select><br />
                <span id="numero2">2</span>
                <select name"liste2">
                    <option value=""></option>
                    <option value="Afghanistan">Afghanistant</option>
                    <option value="Azerbaïdjan">Azerbaïdjan</option>
                    <option value="kirghizistan">Kirghizistan</option>
                    <option value="Pakistan">Pakistan</option>
                    <option value="Tadjikistan">Tadjikistan</option>
                    <option value="Turkménistan">Turkménistan</option>
                    <option value="Ouzbékistan">Ouzbékistan</option>
                </select><br />
                <span id="numero3">3</span>
                <select name"liste3">
                    <option value=""></option>
                    <option value="Afghanistan">Afghanistant</option>
                    <option value="Azerbaïdjan">Azerbaïdjan</option>
                    <option value="kirghizistan">Kirghizistan</option>
                    <option value="Pakistan">Pakistan</option>
                    <option value="Tadjikistan">Tadjikistan</option>
                    <option value="Turkménistan">Turkménistan</option>
                    <option value="Ouzbékistan">Ouzbékistan</option>
                </select><br />
                <span id="numero4">4</span>
                <select name"liste4">
                    <option value=""></option>
                    <option value="Afghanistan">Afghanistant</option>
                    <option value="Azerbaïdjan">Azerbaïdjan</option>
                    <option value="kirghizistan">Kirghizistan</option>
                    <option value="Pakistan">Pakistan</option>
                    <option value="Tadjikistan">Tadjikistan</option>
                    <option value="Turkménistan">Turkménistan</option>
                    <option value="Ouzbékistan">Ouzbékistan</option>
                </select><br />
                <span id="numero5">5</span>
                <select name"liste5">
                    <option value=""></option>
                    <option value="Afghanistan">Afghanistant</option>
                    <option value="Azerbaïdjan">Azerbaïdjan</option>
                    <option value="kirghizistan">Kirghizistan</option>
                    <option value="Pakistan">Pakistan</option>
                    <option value="Tadjikistan">Tadjikistan</option>
                    <option value="Turkménistan">Turkménistan</option>
                    <option value="Ouzbékistan">Ouzbékistan</option>
                </select><br />
                <span id="numero6">6</span>
                <select name"liste6">
                    <option value=""></option>
                    <option value="Afghanistan">Afghanistant</option>
                    <option value="Azerbaïdjan">Azerbaïdjan</option>
                    <option value="kirghizistan">Kirghizistan</option>
                    <option value="Pakistan">Pakistan</option>
                    <option value="Tadjikistan">Tadjikistan</option>
                    <option value="Turkménistan">Turkménistan</option>
                    <option value="Ouzbékistan">Ouzbékistan</option>
                </select><br />
                <span id="numero7">7</span>
                <select name"liste7">
                    <option value=""></option>
                    <option value="Afghanistan">Afghanistant</option>
                    <option value="Azerbaïdjan">Azerbaïdjan</option>
                    <option value="kirghizistan">Kirghizistan</option>
                    <option value="Pakistan">Pakistan</option>
                    <option value="Tadjikistan">Tadjikistan</option>
                    <option value="Turkménistan">Turkménistan</option>
                    <option value="Ouzbékistan">Ouzbékistan</option>
                </select><br />
            </form>
     
            <!-- carte -->
            <div id="carte"><img src="carte.png" height="328"></div>
     
            <!-- boutons -->
            <div id="boutons">
                <input type="submit" name="boutonReset" id="boutonReset" value="Reset" onclick="fonctionReset()">
     
                <input type="submit" name="boutonValider" id="boutonValider" value="Valider" onclick="fonctionValider()">
     
            </div>
     
            <!-- code js -->
            <script src="code.js"></script>
     
        </body>
    </html>

    et mon code JS:

    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
    // jeu des Pays
     
    //Ecriture du titre
    document.getElementById("titre").innerHTML = '<p>Jeu des pays-stan</p>'
     
    //Tableau des pays
    tableauPays = new Array();
    tableauPays[1] = 'Azerbaïdjan';
    tableauPays[2] = 'Turkménistan';
    tableauPays[3] = 'Ouzbékistan';
    tableauPays[4] = 'Afghanistan';
    tableauPays[5] = 'Pakistan';
    tableauPays[6] = 'Tadjikistan';
    tableauPays[7] = 'Kirghizistan';
     
    // fonction Valider
    function fonctionValider(){
        //boucle sur les listes
        for (var i=1; i<=7; i++){
            //récupération de l'index, puis de la valeur choisie
            var indexChoisi = document.forms["listes"].elements["liste"+i].selectedIndex;
            var paysChoisi = document.forms["listes"].elements["liste"+i].options[indexChoisi].value;
            // teste si la liste I affice le bon pays
            if(paysChoisi == tableauPays[i]){
                //changement de style de l'element numéro i
                document.getElementById("numero"+i).style.backgroundColor='#0066CC';
            } else {
                document.getElementById("numero"+i).style.backgroundColor='#FFFFFF';
            }
        }
    }
     
    // fonction Reset
    function fonctionReset(){
        //boucle sur listes
        for (var i = 1; i <= 7; i++) {
            // affichage première valeur
            document.forms["listes"].elements["liste"+i].selectedIndex = 0;
            document.getElementById("numero"+i).style.backgroundColor='#FFFFFF';
        }
    }
    et comme erreur :

    sous FF :
    TypeError: document.forms.listes.elements[("liste" + i)] is undefined code.js:21

    TypeError: document.forms.listes.elements[("liste" + i)] is undefined code.js:38
    et sous chrome :
    Uncaught TypeError: object is not a function code.js:21

    fonctionValider code.js:21

    onclick jeu_pays.html:100

    Uncaught TypeError: object is not a function code.js:38

    fonctionValider code.js:38

    onclick jeu_pays.html:98
    chose qui est embêtant vu que je dois faire à partir de ce code mon exercice .... :-°

  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 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
    manquerait pas un petit "=" là ?

Discussions similaires

  1. [XSD] Liste element > liste attribute
    Par ndupain dans le forum Valider
    Réponses: 2
    Dernier message: 04/12/2008, 10h16
  2. Regrouper une liste en liste de listes
    Par West01 dans le forum Prolog
    Réponses: 12
    Dernier message: 14/03/2008, 14h07
  3. opener.document.forms(i).elements(j).value = xyz ?!
    Par sauceaupistou dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 26/04/2007, 15h56
  4. [Forms]Liste Elements Forms/Base
    Par kikouu dans le forum Forms
    Réponses: 20
    Dernier message: 16/04/2007, 18h52
  5. [Forms] chargement de liste impossible
    Par bargou dans le forum Forms
    Réponses: 17
    Dernier message: 15/02/2005, 09h04

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