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 :

Faire apparaitre/disparaitre une div


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé Avatar de kevinf
    Profil pro
    Développeur informatique
    Inscrit en
    Juin 2005
    Messages
    863
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juin 2005
    Messages : 863
    Par défaut Faire apparaitre/disparaitre une div
    Salut,

    j'ai ce code pour faire apparaitre/disparraitre une div :

    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
    <script language="javascript">
    function hideShow(id_div)
        {
        var img = "image";
        img += id_div ;
        if (document.getElementById(id_div).style.display=='block')
            {
            document.getElementById(id_div).style.display='none'
            document.getElementById(img).src='down.png'
            }
        else
            {
            document.getElementById(id_div).style.display='block'
            document.getElementById(img).src='up.png'
            }    
        }
    </script>
     
    <a href="#"><img src="down.png" name="image1" border="0" id="image1" onClick="hideShow(1)"></a>
    <div id="1" style="display:none ">
    contenu
    </div>
    Ce code faire donc apparaitre/disparraitre "tout d'un coup", comment faire pour que ca fasse comme en cliquand sur le croix à côté de la publicité a droite là : http://www.dailymotion.com/fr/cluste...coup-de-mother

    Merci de votre aide

  2. #2
    Membre Expert
    Avatar de muad'dib
    Homme Profil pro
    Développeur Java
    Inscrit en
    Janvier 2003
    Messages
    1 013
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 43
    Localisation : France, Loire Atlantique (Pays de la Loire)

    Informations professionnelles :
    Activité : Développeur Java
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Janvier 2003
    Messages : 1 013
    Par défaut
    Je n'ai aucune pub à droite.

  3. #3
    Membre Expert
    Homme Profil pro
    Architecte de système d'information
    Inscrit en
    Juillet 2004
    Messages
    2 725
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Sarthe (Pays de la Loire)

    Informations professionnelles :
    Activité : Architecte de système d'information

    Informations forums :
    Inscription : Juillet 2004
    Messages : 2 725
    Par défaut
    Moi non plus, enfin j'ai AdBlock aussi :S

  4. #4
    Membre chevronné
    Inscrit en
    Novembre 2006
    Messages
    336
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 336
    Par défaut
    Pour redéfinir le style par défaut d'un élément via l'object style, on utilise

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    element.style.my_property = '';
    De plus ton getter (la valeur retournée par element.style.my_property) par défaut est vide

    Donc ta fonction ne marchera jamais

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    <script type="text/javascript">
    function $(el) {
    	return document.getElementById(el);
    }
     
    function toggle(id_div) {
    		var img = $("image"+id_div),
    			div = $(id_div),
    			hide = function() {;div.style.display='none';img.src='down.png'},
    			show = function() {div.style.display='';img.src='up.png'};
    			(div.style.display == '') ? hide() : show(); 
    }
    </script>
    Accesoirement, le mieux est de passer par des classes pour cacher et afficher tes éléments, en ajoutant une classe qui applique le display:none

  5. #5
    Membre éclairé Avatar de kevinf
    Profil pro
    Développeur informatique
    Inscrit en
    Juin 2005
    Messages
    863
    Détails du profil
    Informations personnelles :
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur informatique

    Informations forums :
    Inscription : Juin 2005
    Messages : 863
    Par défaut
    Le code que je vous ai donné marche très bien. Je voulais juste que la disparition se fasse progressive comme l'apparition.

  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
    marche pas chez moi ...

    mais bon je suppose qu'il doit s'agir d'un setInterval qui modifie l'opacité ...
    une petite recherche sur le forum te donnera les code crossbrowser pour l'opacité (parceque là il à pas l'air crossbrowser) j'en ai parlé il n'y a pas très longtemps ...
    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 !

  7. #7
    Membre chevronné
    Inscrit en
    Novembre 2006
    Messages
    336
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 336
    Par défaut
    Citation Envoyé par kevinf
    Le code que je vous ai donné marche très bien. Je voulais juste que la disparition se fasse progressive comme l'apparition.
    Marche pas leur truc

    Essaye bytefx avec cette fonction :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    	function toggle(id_div) {
    			var img = $("image"+id_div),
    				div = $(id_div),
    				hide = function() {bytefx.fade(div , 100, 0, 2, function(){this.style.display='none'});img.src='down.png'},
    				show = function() {div.style.display='';bytefx.fade(div , 0, 100, 2, function(){});img.src='up.png'};
    				(div.style.display == '') ? hide() : show(); 
    }
    Ca devrait marcher
    Edit : La version "packer"

    Citation Envoyé par SpaceFrog
    marche pas chez moi ...

    mais bon je suppose qu'il doit s'agir d'un setInterval qui modifie l'opacité ...
    une petite recherche sur le forum te donnera les code crossbrowser pour l'opacité (parceque là il à pas l'air crossbrowser) j'en ai parlé il n'y a pas très longtemps ...
    Non, setInterval est beaucoup trop lent pour ce genre d'effet.

Discussions similaires

  1. Réponses: 9
    Dernier message: 21/10/2014, 18h08
  2. Faire apparaitre/disparaitre une vidéo en Javascript
    Par spoker04 dans le forum Développement Web en Java
    Réponses: 1
    Dernier message: 11/05/2010, 17h26
  3. faire disparaitre une div automatiquement
    Par Darkcristal dans le forum jQuery
    Réponses: 2
    Dernier message: 19/11/2009, 19h11
  4. faire apparaitre/disparaitre une zone de text
    Par aabdoos dans le forum MFC
    Réponses: 1
    Dernier message: 30/12/2006, 10h50
  5. Faire apparaitre/disparaitre une div sans javascript
    Par TocTocKiéLà? dans le forum Balisage (X)HTML et validation W3C
    Réponses: 9
    Dernier message: 25/09/2006, 12h02

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