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 :

balise div non visible par getElementById


Sujet :

JavaScript

  1. #1
    Membre éprouvé Avatar de bluemartini
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    154
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Avril 2006
    Messages : 154
    Par défaut balise div non visible par getElementById
    Salut,

    Je suis en train de me former à javascript, et je galère sur un cas qui me semble simple depuis une journée maintenant...

    voici mon code HTML :
    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
    <HTML>
    <HEAD>
    	<link rel="stylesheet" href="css/style.css" type="text/css" media="screen" />
    	<script type="text/javascript" src="javascript/prototype.js"></script>
     
    <TITLE> in dev </TITLE>
    </HEAD>
    <BODY>
     
     
    <FORM name="administrative" method="post" action="#">
    		species : <SELECT name="species" id="choiceSpecies" onfocusin="population.populate_species()">
    				<OPTION value="NA">NA</OPTION>
    				<div id="speciesOptions" >
    					<OPTION value="NA">NA</OPTION>
    				</div>
    			  </SELECT>
     
     
     
    		<br/><input id="data" autocomplete="off" size="83" type="text" value="" onfocusin="population.populate_data()"/>
     
    </FORM>
    <script type="text/javascript" src="js_code.js"></script>	
     
    </BODY>
    </HTML>
    et voici mon code javascript :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    alert(document.getElementById('choiceSpecies')[0].nodeType);
    alert(document.getElementById('speciesOptions')[0].nodeType);
    Le résultat : j'ai le type de la balise SELECT qui est affiché, mais javascript ne retourne rien pour le deuxieme appel, concernant le type de la balise div.

    Quelqu'un saurait me dire pourquoi?
    merci!

  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
    contrairement à getElementsByName ou getElementsByTagName getElementById ne retourne pas une collection puisque un id est unique sur la page ...
    On remarquera dans la syntaxe l'absence de pluriel à Element ...


    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alert(document.getElementById('choiceSpecies').nodeType);
    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 éprouvé Avatar de bluemartini
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    154
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Avril 2006
    Messages : 154
    Par défaut
    merci pour ta réponse!
    Effectivement la notation d'accès au tableau était en trop.
    Cependant, cela ne résout pas le problème. En simplifiant mon code :

    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
    <HTML>
    <HEAD>
    	<script type="text/javascript" src="javascript/prototype.js"></script>
    	<TITLE> in dev </TITLE>
    </HEAD>
    <BODY>
     
    <FORM name="administrative" method="post" action="#">
    		species : <SELECT name="species" id="choiceSpecies">
    				<OPTION value="NA">NA</OPTION>
    				<div id="speciesOptions" >
    					<OPTION value="NA">NA</OPTION>
    				</div>
    			  </SELECT>
     
     
    </FORM>
    <script type="text/javascript">
    	alert(document.getElementById('speciesOptions').nodeType);
    </script>	
     
    </BODY>
    </HTML>
    aucun message s'affiche.

  4. #4
    Expert confirmé
    Avatar de Auteur
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    7 660
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 7 660
    Par défaut
    bonjour;

    Code html : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    				<div id="speciesOptions" >
    					<OPTION value="NA">NA</OPTION>
    				</div>

    On ne peut pas encadrer de balise option d'un div ni même écrire une balise HTML dans une balise option.

    En passant : écris toutes tes balises HTML en minuscules, sinon ça ne passe pas la validation W3C.

  5. #5
    Membre éprouvé Avatar de bluemartini
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    154
    Détails du profil
    Informations personnelles :
    Âge : 45
    Localisation : France, Hérault (Languedoc Roussillon)

    Informations forums :
    Inscription : Avril 2006
    Messages : 154
    Par défaut
    Merci beaucoup!
    Effectivement c'est de là que venait le problème. Par contre, je ne comprend pas cette règle. Pourquoi définir qu'un select ne possède que des balises option?
    Et merci pour le conseil W3C, c'est enregistré!

  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
    le html est un langage structuré ...
    pourquoi definir qu'une page html doit avoir un head et un body ...
    un select est ainsi fait ...
    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 !

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

Discussions similaires

  1. disque scsi non visible par l'install XP
    Par pierrot82 dans le forum Windows XP
    Réponses: 2
    Dernier message: 24/08/2009, 10h31
  2. [MySQL] Balises HTML non interprétées par MySQL
    Par antow42 dans le forum PHP & Base de données
    Réponses: 5
    Dernier message: 30/04/2009, 10h40
  3. package ascb.util.numberUtilities Non visible par flash CS3
    Par amateur_will dans le forum ActionScript 3
    Réponses: 1
    Dernier message: 18/07/2008, 06h49
  4. Dimension de div non respectée par Firefox
    Par Zelphalya dans le forum Mise en page CSS
    Réponses: 4
    Dernier message: 05/01/2007, 13h15
  5. Réponses: 2
    Dernier message: 18/07/2005, 11h58

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