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 :

Petit soucis d'affichage avec javascript


Sujet :

JavaScript

  1. #1
    Membre émérite
    Avatar de polymorphisme
    Homme Profil pro
    Publishing
    Inscrit en
    Octobre 2009
    Messages
    1 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Publishing
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2009
    Messages : 1 460
    Points : 2 371
    Points
    2 371
    Par défaut Petit soucis d'affichage avec javascript
    Bonjour à tous,

    j'ai un soucis avec un script qui permet d'afficher des blocs pour des nouvelles.

    La structure HTML est simple : le premier bloc est un titre, le second bloc est un texte. Lorsque l'on clique sur un bloc titre, le bloc texte est sensé s'afficher s'il était invisible ou devenir invisible s'il était affiché.

    Enfin, le premier couple de bloc titre/texte doit être avoir un texte affiché afin que la présentation soit correcte, malheureusement, avec le code ci-dessous, il faut cliquer deux fois sur le titre de la première nouvelle pour que le texte devienne invisible, vous l'aurez deviner, c'est le soucis !

    Je cherche donc comment faire pour que l'on ait besoin de cliquer une seule fois sur le titre de la première nouvelle pour que le texte devienne invisible.

    Voici le code complet (il est aussi disponible dans l'archive zip avec les images qui vont bien avec)

    Merci de vos lumières.

    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
     
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head>
    <style type="text/css">
    .displayNone { display: none; }
    .displayBlock { display: block; }
    .displayOpen { background: url('iconNavOpenGray-32x32.png') no-repeat center left; }
    .displayClose { background: url('iconNavCloseGray-32x32.png') no-repeat center left; }
    </style>
     
    <script type="text/javascript">
     function displayBlock(obj){
      var open = 'url("iconNavOpenGray-32x32.png")';
      var close = 'url("iconNavCloseGray-32x32.png")';
     
      if(document.getElementById)  {
        var el = document.getElementById(obj);
        var title = document.getElementById(obj+'Head');
     
        if(el.style.display != "block"){ 
          title.style.backgroundImage = open;
          el.style.display = "block";
        }else{
          title.style.backgroundImage = close;
          el.style.display = "none";
        }
      }
    }
    </script>
    </head>
    <body>
     
    <h2 class="displayOpen" onclick="displayBlock('N10022')" id="N10022Head">
    La bataille de l’Atlantique commence !
    </h2>
    <div class="displayBlock" id="N10022">
    Lorem ipsum dolor sit amet, consectetuer adipiscing elit, sed diam nonummy nibh euismod.
    </div>
     
    <h2 class="displayClose" onclick="displayBlock('N10031')" id="N10031Head">
    Du cap Horn aux îles Wollaston
    </h2>
    <div class="displayNone" id="N10031">
    Puis autem vel eum iriure dolor in hendrerit in vulputate velit esse molestie consequat.
    </div>
     
    </body>
    </html>
    Fichiers attachés Fichiers attachés

  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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    les displays sont ils initialisés dans le css ? vu qu'il ne le sont pas au niveau des balises ...

  3. #3
    Membre émérite
    Avatar de polymorphisme
    Homme Profil pro
    Publishing
    Inscrit en
    Octobre 2009
    Messages
    1 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Publishing
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2009
    Messages : 1 460
    Points : 2 371
    Points
    2 371
    Par défaut
    Bonjour SpaceFrog,

    les displays sont ils initialisés dans le css ?
    C'est-à-dire ?

  4. #4
    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 663
    Points
    66 663
    Billets dans le blog
    1
    Par défaut
    lors du premier click tes objets n'ont pas de display...

  5. #5
    Expert confirmé
    Avatar de javatwister
    Homme Profil pro
    danseur
    Inscrit en
    Août 2003
    Messages
    3 681
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Calvados (Basse Normandie)

    Informations professionnelles :
    Activité : danseur

    Informations forums :
    Inscription : Août 2003
    Messages : 3 681
    Points : 5 221
    Points
    5 221
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    if(el.style.className==".displayBlock"){
         el.style.className=".displayNone";
         title.style.backgroundImage = open;
    }
    else{
         el.style.className=".displayBlock";
         title.style.backgroundImage = close;
    }

  6. #6
    Membre émérite
    Avatar de polymorphisme
    Homme Profil pro
    Publishing
    Inscrit en
    Octobre 2009
    Messages
    1 460
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 51
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Publishing
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2009
    Messages : 1 460
    Points : 2 371
    Points
    2 371
    Par défaut
    Voici une solution fonctionnelle :

    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
    function displayBlock(id) {
     
      if (document.getElementById) {
        var title = document.getElementById(id+"Head");
        var el = document.getElementById(id);
     
        if (el.className == "displayBlock") {
          title.className = "displayClose";
          el.className = "displayNone"; }      
        else {      
    	  title.className = "displayOpen";        
    	  el.className = "displayBlock";               
        }
      }
    }
    Merci à tous deux.

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

Discussions similaires

  1. Petit soucie de sérialisation avec .net remoting
    Par teddyalbina dans le forum C#
    Réponses: 2
    Dernier message: 22/03/2008, 21h34
  2. Soucis d'affichage avec MSIE (balise HR)
    Par Olivier Regnier dans le forum Mise en page CSS
    Réponses: 2
    Dernier message: 15/11/2007, 19h17
  3. Réponses: 5
    Dernier message: 05/11/2007, 23h30
  4. Réponses: 3
    Dernier message: 20/10/2007, 18h54
  5. [Zip] petit soucis de variable avec "zip.lib.php"
    Par Giantrick dans le forum Bibliothèques et frameworks
    Réponses: 2
    Dernier message: 29/06/2007, 12h19

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