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

jQuery Discussion :

Animation au passage de la souris


Sujet :

jQuery

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Février 2010
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 45
    Points : 45
    Points
    45
    Par défaut Animation au passage de la souris
    Bonjour,

    J'aimerais faire une barre de navigation avec un petit effet (grossissement du texte) lorsque la souris passe sur un des liens. J'arrive presque à faire ce que je veux avec la fonction 'animate' mais parfois l'animation se répète plusieurs fois avant de se fixer. Par exemple je mets la souris sur un lien du menu, le texte grossit, reviens a sa taille normale, puis grossit de nouveau, au lieu de grossir une fois tout simplement. Je ne sais pas si c'est très clair... Je vous mets le code JS :

    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
    $("#divnews").mouseover(function(){
     
    		  $(this).animate({ 
    			fontSize: "18px"
    		  }, 300 );
     
    });
     
    $("#divnews").mouseout(function(){
     
    		  $(this).animate({ 
    			fontSize: "16px"
    		  }, 100 );
     
    });
    Si quelqu'un peut éclairer ma lanterne, ce serait sympa..
    Merci !

  2. #2
    Membre éclairé Avatar de pop_up
    Profil pro
    Inscrit en
    Avril 2006
    Messages
    877
    Détails du profil
    Informations personnelles :
    Localisation : France, Rhône (Rhône Alpes)

    Informations forums :
    Inscription : Avril 2006
    Messages : 877
    Points : 786
    Points
    786
    Par défaut
    J'ai essayé ce code, ça a l'air de fonctionner.

    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
     
    <!doctype html>
    <html>
      <head>
      <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js"></script>
      <script type="text/javascript">
        $(document).ready(function(){
            $("#divnews").mouseover(function(){
                $("#divnews").animate({
                    fontSize: "3em", 
                }, 300 );
     
            });
     
            $("#divnews").mouseout(function(){
     
            $(this).animate({
            fontSize: "1em"
            }, 100 );
     
            });
        });
      </script>
     
      <style>
     
      div { 
        background-color:#bca; 
        width:100px; 
        border:1px solid green;
      }
     
      </style>
      </head>
      <body>
     
      <div id="divnews">Hello!</div>
      </body>
      </html>
    Si c'est pas le cas chez toi, met le code complet pour qu'on puisse tester exactement ton cas.

  3. #3
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

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

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Ce n'est pas directement lié au sujet, mais plutôt que mouseover et mouseout, on peut avantageusement utiliser l'événement jQuery .hover() qui prend en paramètres le code à exécuter lors du mouseover et celui du mouseout.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    $("#divnews").hover(
        function(){
            $("#divnews").animate({
                fontSize: "3em", 
            }, 300 )
        },
        function(){
            $(this).animate({
                fontSize: "1em"
            }, 100 );
        }
    );
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  4. #4
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Points : 22 933
    Points
    22 933
    Billets dans le blog
    125
    Par défaut
    Citation Envoyé par eddynamique Voir le message
    ... mais parfois l'animation se répète plusieurs fois avant de se fixer.
    Ce problème est du a mouseover, hover simplifie l'écriture, mais n'améliore rien, car il utilise mouseover en interne.

    On peut remplacer mouseover par l'événement mouseenter et mouseout par mouseleave.

    Si l'utilisateur passe son temps à promener le pointeur sur la zone à animer le problème est moindre avec mouseenter mais il existe toujours.

    Voir la démo à la fin de http://api.jquery.com/mouseover/

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

  5. #5
    Membre régulier
    Homme Profil pro
    Inscrit en
    Décembre 2007
    Messages
    233
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations forums :
    Inscription : Décembre 2007
    Messages : 233
    Points : 107
    Points
    107
    Par défaut
    C'est du au fait que JQuery empile tes evenements et les execute donc X fois les uns apres les autres si tu fais X passages sur ton lien. Essaies ceci :

    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
    $("#divnews").mouseover(function(){
    				  
    		  $(this).stop().animate({ 
    			fontSize: "18px"
    		  }, 300 );
      
    });
    		
    $("#divnews").mouseout(function(){
    				  
    		  $(this).stop().animate({ 
    			fontSize: "16px"
    		  }, 100 );
      
    });

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Février 2010
    Messages
    45
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2010
    Messages : 45
    Points : 45
    Points
    45
    Par défaut
    Merci pour vos réponses. J'ai résolu mon problème en remplaçant "mouseover" et "mouseout" par "mouseenter" et "mouseleave". Mais j'aimerais savoir quelle est la différence entre $("#divnews").mouseenter() et $("#divnews").stop().mouseenter(), car je ne vois pas de différence.

    Merci

  7. #7
    Rédacteur

    Avatar de danielhagnoul
    Homme Profil pro
    Étudiant perpétuel
    Inscrit en
    Février 2009
    Messages
    6 389
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 73
    Localisation : Belgique

    Informations professionnelles :
    Activité : Étudiant perpétuel
    Secteur : Enseignement

    Informations forums :
    Inscription : Février 2009
    Messages : 6 389
    Points : 22 933
    Points
    22 933
    Billets dans le blog
    125
    Par défaut
    Bonsoir.

    stop() : http://api.jquery.com/stop/

    Sert à arrêter l'animation en cours, avis personnel : manipulation délicate et il ne sert à rien dans l'exemple donné.

    Blog

    Sans l'analyse et la conception, la programmation est l'art d'ajouter des bogues à un fichier texte vide.
    (Louis Srygley : Without requirements or design, programming is the art of adding bugs to an empty text file.)

Discussions similaires

  1. Afficher animation flash au passage de la souris
    Par jlb59 dans le forum Flash
    Réponses: 10
    Dernier message: 05/05/2010, 06h20
  2. Réponses: 2
    Dernier message: 21/03/2010, 20h25
  3. Animation qui s'agrandit au passage de la souris
    Par gansie dans le forum Flash
    Réponses: 3
    Dernier message: 23/01/2009, 18h25
  4. Animation au passage de souris
    Par solorac dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 14/11/2008, 11h10
  5. changer couleur du lien au passage de la sourie
    Par toome dans le forum Balisage (X)HTML et validation W3C
    Réponses: 3
    Dernier message: 01/08/2005, 10h11

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