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 :

Optimisation d'un display "none"


Sujet :

JavaScript

  1. #1
    Membre habitué
    Inscrit en
    Avril 2005
    Messages
    269
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 269
    Points : 172
    Points
    172
    Par défaut Optimisation d'un display "none"
    Bonjour ,

    J'ai un petit script qui me permet de deployer ou non un div en fonction d'un clic sur un lien
    (le clic sur le lien permet de monter le div non apparent au depart et de le cacher par un second clic et ainsi de suite)
    Cependant quand j'en ai plusieurs sur une page je souhaiterais que l'ouverture d'un permette de fermer l'autre qui est ouvert pour n'en fait n'en afficher seulement un a la fois.

    Est-ce possible ?

    voici mon code actuel :

    le script :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    function cache(id){
    	document.getElementById(id).style.display = (document.getElementById(id).style.display == "none")?(""):("none");
    }
    le div
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    echo "<div style=cursor:pointer class=... onclick=cache('menu1')>Critiquer ".$row["user_prenom"]."</div>";
    	echo "<div style=display:none id=menu1>";
    Actuellement quand j'utilise cette technique pour tout mes div cachés ils sont tous independant et peuvent s'ouvrir et ce fermer sans que cela touche aux autre (ce que je voudrais justement changer... )

  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
    Bonjour,
    il faut que ton script boucle sur les div de ta page et masque ceux dont l'id est différent du paramètre passé.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    	for (i=0; i<document.getElementsByTagName("div").length; i++)
    		document.getElementsByTagName("div")[i].style.display = (document.getElementsByTagName("div")[i].id == ton_param)?"block":"none";
    Tu noteras que la valeur de display est 'block' pour afficher (autant éviter de compter sur les valeurs par défaut) ...
    EDIT : Attention, si tu as des div qui ne doivent pas être concernés, il faut ajouter une condition pour les exclure du test ...

    A+
    Pour tout savoir sur l'utilisation du forum

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

  3. #3
    Modérateur
    Avatar de Bisûnûrs
    Profil pro
    Développeur Web
    Inscrit en
    Janvier 2004
    Messages
    9 868
    Détails du profil
    Informations personnelles :
    Âge : 41
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Janvier 2004
    Messages : 9 868
    Points : 16 258
    Points
    16 258
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    function cache(id){
       for(var i = 1; i <= 3; i++){ // où 3 est le nombre de "menu"
          document.getElementById('menu'+i).style.display = "none";
       }
       document.getElementById(id).style.display = (document.getElementById(id).style.display == "none") ? "block" : "none";
    }

  4. #4
    Membre habitué
    Inscrit en
    Avril 2005
    Messages
    269
    Détails du profil
    Informations forums :
    Inscription : Avril 2005
    Messages : 269
    Points : 172
    Points
    172
    Par défaut
    merci pour ttes ces infos ca m'a l'air o poil !

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

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