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 :

Cacher tous les divs contenus dans un autre div


Sujet :

JavaScript

  1. #1
    Membre actif Avatar de baggie
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    755
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 755
    Points : 262
    Points
    262
    Par défaut Cacher tous les divs contenus dans un autre div
    Bonjour

    Dans un div, j'ai une liste d'items.
    Toujours dans ce div, j'ai d'autres divs : un pour chaque item, en "display:none".

    Quand je clique sur un item, ça affiche le div correspondant.

    Comment faire pour cacher tous les autres divs qui pourraient être déja affichés et n'afficher que le div concerné ?

    J'ai regardé sur le forum et sur Google, j'ai testé :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    function showdiv(name)
    {
    	document.getElementsByTagName('div').style.display="none";
    	document.getElementById(name).style.display="block";
    }
    mais ça ne fonctionne pas, d'autant plus que j'ai peur de cacher tous les divs de ma page en faisant ça et je ne veux pas.

    Résumé de 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
     
    <div id="contenu">
       <div id="blabla">
         <div id="truc">Un autre truc</div>
         <div>
    	<h3>Un titre</h3>
    	  <ul>
    		<li>Un autre titre</li>
    	        <ul>
    			<li onClick="showdiv('itemun')">Item1</li>
    			<li onClick="showdiv('itemdeux')">Item2</li>
    		</ul>
               </ul>
           </div>
        </div>
    </div>
    J'ai lu sur un topic qu'il fallait juste prendre la collection document.getElementsByTagName('div') mais j'avoue que je n'ai pas bien compris

    Quelqu'un pourrait-il m'aider ?

  2. #2
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Salut
    Citation Envoyé par baggie Voir le message
    J'ai lu sur un topic qu'il fallait juste prendre la collection document.getElementsByTagName('div') mais j'avoue que je n'ai pas bien compris

    Qu'est-ce que tu ne comprends pas la dedans ?
    document.getElementsByTagName('div') te retourne un tableau d'éléments.
    Il suffit de la parcourir ...
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById('truc').getElementsByTagName('div')
    te sort (sans risque) la liste des div contenus dans "truc" ...

    A+
    Pour tout savoir sur l'utilisation du forum

    En postant votre message, n'oubliez pas les Règles du Club.

  3. #3
    Membre actif Avatar de baggie
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    755
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 755
    Points : 262
    Points
    262
    Par défaut
    Merci E.Bzz pour ta réponse.

    Ce que je ne comprends pas, c'est quoi écrire exactement pour cacher les divs puisque :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById('elemliste').getElementsByTagName('div').style.display = "none";
    ne fonctionne pas, alors que moi ça me paraît on ne peut plus logique

    EDIT : un while pour faire un parcours sur chaque div ?

    EDIT 2 : j'ai vu que dans mon code au-dessus (premier post) j'avais oublié les div à afficher quand on passe sur l'item correspondant, donc en gros sous le <div> contenant mes item, j'ai tous les autres <div> les uns sous les autres.

  4. #4
    Expert éminent sénior

    Homme Profil pro
    Inscrit en
    Janvier 2007
    Messages
    13 474
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Secteur : Finance

    Informations forums :
    Inscription : Janvier 2007
    Messages : 13 474
    Points : 36 571
    Points
    36 571
    Par défaut
    Citation Envoyé par baggie Voir le message
    ne fonctionne pas, alors que moi ça me paraît on ne peut plus logique
    Comme quoi, toute logique est relative
    document.getElementsByTagName('div') te retourne un tableau d'éléments.
    Tableau c'est dans le sens Array(), et pas <table>.
    Donc pour accéder à un des éléments du tableau, il faut un indice
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById('elemliste').getElementsByTagName('div')[i].style.display = "none";
    i étant incrémenté par ta boucle (de 0 à document.getElementById('elemliste').getElementsByTagName('div').length).

    Sur le principe, il te suffit de tout passer en display="none" dans ta boucle, puis de passer explicitement le display de celui que tu veux afficher (dont tu auras pris soins de passer l'id en paramètre de ta fonction) à "block".

    A+
    Pour tout savoir sur l'utilisation du forum

    En postant votre message, n'oubliez pas les Règles du Club.

  5. #5
    Membre actif Avatar de baggie
    Profil pro
    Inscrit en
    Octobre 2007
    Messages
    755
    Détails du profil
    Informations personnelles :
    Âge : 35
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Octobre 2007
    Messages : 755
    Points : 262
    Points
    262
    Par défaut
    Merci pour ton aide, ça fonctionne parfaitement !

    (suffit juste de bien savoir où placer ses div pour ne pas tous les cacher )

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

Discussions similaires

  1. [AC-2003] afficher tous les critères contenus dans une zone de liste modifiable
    Par facteur dans le forum VBA Access
    Réponses: 3
    Dernier message: 20/03/2014, 17h21
  2. [XL-2007] FICHIER.XLSX qui reprend le nom de tous les fichiers contenus dans le meme repertoire ?
    Par century94 dans le forum Macros et VBA Excel
    Réponses: 19
    Dernier message: 21/05/2012, 02h43
  3. Réponses: 10
    Dernier message: 17/04/2009, 17h19
  4. Réponses: 1
    Dernier message: 01/12/2008, 18h03
  5. la meilleure solution pour centrer un div contenu dans un autre div ?
    Par Acid-dev dans le forum Général JavaScript
    Réponses: 6
    Dernier message: 04/01/2007, 10h00

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