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 :

fonction "cache/décache" pour galerie


Sujet :

JavaScript

  1. #1
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 35
    Points : 25
    Points
    25
    Par défaut fonction "cache/décache" pour galerie
    Bonjour à tous,

    Je suis en train de réaliser une gallerie d'image, l'idée, vous la connaissez, c'est de mettre des petits thumbnails les uns à côté des autres en réduit, et, quand on clique dessus, qu'il apparaisse en grand.

    j'ai donc un <table> avec mes vignettes et plus loin, une div de destinations des grand format.

    Le souçis, c'est que quand je clique sur 1 photo, elle s'affiche. Puis quand je clique sur 1 autre photo, elle s'affiche sans que la première disparaisse...

    embêtant hein?!


    Ma fonction JS:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    <script type="text/javascript">
    //------------------
    function Swap( div_){
      var Obj = document.getElementById( div_);
      if( Obj){
        if( Obj.style.display=="")
          Obj.style.display="none";
        else
          Obj.style.display="";
      }
    }
    </script>


    mon code pour les vignettes:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    <table>
    <tr>
     
    <td><a href="#Photo1"  onclick="Swap('DIV_Photo1');">
    <img src="images/photo1.png"  width="140" id="gallerie">
    </a></td>
     
    <td><a href="#Photo2"  onclick="Swap('DIV_Photo2');">
    <img src="images/photo2.png"  width="140" id="gallerie">
    </a></td>
     
    </tr>
    </table>
    et enfin le code de la div de destination du grand format:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    <table>
    <tr>
    <td>
    <div id="DIV_Photo1" style="display:none" >
    <img src="images/photo1.png" width="100%"></div>
     
    <div id="DIV_Photo2" style="display:none" >
    <img src="images/photo2.png" width="100%"></div>
    </td>
    </tr>
    </table>
    Vous pourriez m'aider? 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 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
    un id doit être unique sur la page
    une action js decelnché par un href doit etre suivie d'une inhibition du href (return false)

    ensuite il faut boucler sur les images à chaque click et tester si l'image de ma boucle est l'image cliquée et attribuer le display en conséquence

    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
    <script type="text/javascript">
    //------------------
    function Swap(imgactive){
    var i=0;
    curr=document.getElementById(imgactive)
    while (pic=document.getElementById('DIV_Photo'+(++i))){
    	pic.style.display = (pic==curr)?"":"none";
      }
    }
    </script>
    </head>
     
    <body>
    <table>
    <tr>
     
    <td><a href="#Photo1"  onclick="Swap('DIV_Photo1');return false;">
    <img src="img/1.png"  width="140" id="gallerie1">
    </a></td>
     
    <td><a href="#Photo2"  onclick="Swap('DIV_Photo2');return false;">
    <img src="img/2.png"  width="140" id="gallerie2">
    </a></td>
     
    </tr>
    </table>
    <table>
    <tr>
    <td>
    <div id="DIV_Photo1" style="display:none" >
    <img src="img/1.png" width="100%"></div>
     
    <div id="DIV_Photo2" style="display:none" >
    <img src="img/2.png" width="100%"></div>
    </td>
    </tr>
    </table>
     
     
     </body>
     
    </html>

  3. #3
    Nouveau membre du Club
    Profil pro
    Inscrit en
    Janvier 2010
    Messages
    35
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Janvier 2010
    Messages : 35
    Points : 25
    Points
    25
    Par défaut
    Citation Envoyé par SpaceFrog Voir le message
    un id doit être unique sur la page
    une action js decelnché par un href doit etre suivie d'une inhibition du href (return false)

    ensuite il faut boucler sur les images à chaque click et tester si l'image de ma boucle est l'image cliquée et attribuer le display en conséquence

    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
    <script type="text/javascript">
    //------------------
    function Swap(imgactive){
    var i=0;
    curr=document.getElementById(imgactive)
    while (pic=document.getElementById('DIV_Photo'+(++i))){
    	pic.style.display = (pic==curr)?"":"none";
      }
    }
    </script>
    </head>
     
    <body>
    <table>
    <tr>
     
    <td><a href="#Photo1"  onclick="Swap('DIV_Photo1');return false;">
    <img src="img/1.png"  width="140" id="gallerie1">
    </a></td>
     
    <td><a href="#Photo2"  onclick="Swap('DIV_Photo2');return false;">
    <img src="img/2.png"  width="140" id="gallerie2">
    </a></td>
     
    </tr>
    </table>
    <table>
    <tr>
    <td>
    <div id="DIV_Photo1" style="display:none" >
    <img src="img/1.png" width="100%"></div>
     
    <div id="DIV_Photo2" style="display:none" >
    <img src="img/2.png" width="100%"></div>
    </td>
    </tr>
    </table>
     
     
     </body>
     
    </html>
    Tu marque un point!
    Merci beaucoup!!

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

Discussions similaires

  1. [SQL] magic quotes ou double apostrophes pour échapper apostrophe
    Par zorian dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 13/03/2006, 16h23

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