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 :

utiliser plusieurs fois la même animation jquery


Sujet :

jQuery

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

    Informations forums :
    Inscription : Février 2011
    Messages : 253
    Points : 56
    Points
    56
    Par défaut utiliser plusieurs fois la même animation jquery
    Bonjour, j'ai créé a partir de plusieurs images (flèche) une animation qui fait disparaître puis réapparaître les flèches les unes après les autres (continuellement) (en jquery).

    Sauf erreur dans l'utilisation de cette animation, est-il possible d'utiliser plusieurs fois cette animation à des endroits différents sur une page d'un site?

    la partie jquery de l'animation se trouve dans le fichier detail_lien.js
    l'affichage de l'animation se trouve sur une page fleche.php
    et celle-ci est appelée en php avec un include dans la page principale du site (index.php).

    actuellement avec cette configuration d'appel de page et d'animation, seul le premier appel de l'animation marche sur les deux afficher.

    merci pour vos explications et réponses

  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
    elle est codée comment cette animation ?

    si tu l'affectes au moyen d'un selecteur cela ne pose aucun souci

  3. #3
    Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    253
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 253
    Points : 56
    Points
    56
    Par défaut
    voici mes codes:
    affichage de l'animation (avec images) fleche.php (images dans le fichier css):
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
    <?php echo"
            <div class='fleche-lien'>
        <table cellpadding='0' cellspacing='0'  width='62px'>
        <tr>
        <td width='15px'>   <div id='fleche1'></div>        </td>
        <td width='15px'>    <div id='fleche2'></div>       </td>
        <td width='15px'>    <div id='fleche3'></div>       </td>
        <td width='15px'>    <div id='fleche4'></div>       </td>
        </tr>
        </table>
        </div>      
            ";
    ?>
    codage de l'animation (jquery):detail_lien.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
     
    function animfleche(){
    	$('#fleche1').delay(200).fadeOut(200);
    	$('#fleche2').delay(400).fadeOut(200);
    	$('#fleche3').delay(600).fadeOut(200);
    	$('#fleche4').delay(800).fadeOut(200);
     
    	$('#fleche1').delay(1000).fadeIn(300);
    	$('#fleche2').delay(1200).fadeIn(300);
    	$('#fleche3').delay(1400).fadeIn(300);
    	$('#fleche4').delay(1600).fadeIn(300);
    	}
    $(document).ready(function(){
    	setInterval('animfleche();',3000);
    });
    enfin recuperation du fichier fleche.php dans la page principale (index.php):
    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
     
    <link rel="stylesheet" type="text/css" href="style.css" />
    <script type="text/javascript" src="jquery.js"></script>
    <script type="text/javascript" src="detail_liens.js"></script>
    <div>
    <div id="acces">
                    <table>
                    <tr>
                    <td width="70%" style="font-size:11px; border:px solid black; color:#333" > Acceder aux tutoriels</td>
                    <td width="30%"><?php include('fleche.php'); ?></td>
                    </tr>
                    </table>
                </div>
    </div>
    <div>
    <div id="acces">
                <table>
                    <tr>
                    <td width="70%" style="font-size:11px; border:px solid black; color:#333" > Acceder aux technologies</td>
                    <td width="30%"><?php include('fleche.php'); ?></td>
                    </tr>
                    </table>
                </div>
    </div>
    pourriez vous expliquez selecteur, car je n'est tjs pas assimiler les termes informatique ?

  4. #4
    Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    253
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 253
    Points : 56
    Points
    56
    Par défaut
    Une question en parralèle , j'aimerais savoir si c normal, par rapport au code jquery de l'animation , que celle-ci bug à un certain moment (soit: que les flèches ne disparaissent/apparaissent plus dans l'ordre mais dans le désordre)
    environ 3à 5 min après le debut de l'animation

  5. #5
    Membre chevronné
    Avatar de gwinyam
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2006
    Messages
    1 162
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 162
    Points : 2 015
    Points
    2 015
    Par défaut
    Trace sur une ligne de temps ce que tu demandes à ton script de faire et vérifie bien la doc de .delay() avant de le faire, enfin surtout la façon dont elle s'exécute. Tu comprendras très vite le pourquoi de ta dernière question.

    Tu vas voir qu'en réalité, tu fais des appels à des fonctions qui sont demandés dans le temps mais qui ne bloquent pas l'exécution à un stade précis de ta fonction. Du coup tous tes appels sont empilés comme ça à la volée. La première fois, niquel mais après bah ça devient n'importe quoi. Comme tu as pu le constater.

    Pour ta première question, oui c'est toujours réutilisable mais il faut que tu modifies quelque peu ton script pour le rendre "dynamique". Dans le sens où en paramètres, tu dois lui passer la liste des identifiants de tes flèches plutôt que de les écrire en dur dans ta fonction.

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

    Informations forums :
    Inscription : Février 2011
    Messages : 253
    Points : 56
    Points
    56
    Par défaut
    merci beaucoup pour ton explication gwinyam

    j'ai modifié mon code jquery , je n'ai pas encore remarqué de probleme dans le temps, donc ça devrait être bon,

    cependant, j'en demande peut être un peu trop, mais pourrais -je avoir un exemple de :
    citation "Dans le sens où en paramètres, tu dois lui passer la liste des identifiants de tes flèches plutôt que de les écrire en dur dans ta fonction."

    serait-ce par hazard de variable dont tu parles ??
    ex: var fleche1 = f1;

    merci encore

  7. #7
    Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    253
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 253
    Points : 56
    Points
    56
    Par défaut
    bon apparemment le probleme de l'animation n'est pas résolu , après 7 min,
    cad plus de 140 répétitions , l'animation bug et les fleches s'affiche dans le désordre.

    De plus le site api.jquery.com/delay ne m'explique pas plus que ce que j'ai déjà compris.
    voici le code :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
     
    function animfleche(){
     
    	$('#fleche1').fadeIn(200).delay(100).fadeOut(200);
    	$('#fleche2').delay(200).fadeIn(200).delay(300).fadeOut(200);
    	$('#fleche3').delay(400).fadeIn(200).delay(500).fadeOut(200);
    	$('#fleche4').delay(600).fadeIn(200).delay(700).fadeOut(200);
     
    }
     
    $(document).ready(function(){
    	setInterval('animfleche();',2800);
    });

  8. #8
    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
    lance les enchainements dans les callbacks ...

  9. #9
    Membre chevronné
    Avatar de gwinyam
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2006
    Messages
    1 162
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 162
    Points : 2 015
    Points
    2 015
    Par défaut
    Citation Envoyé par artenis Voir le message
    serait-ce par hazard de variable dont tu parles ??
    ex: var fleche1 = f1;
    Tout à fait, mais attention, surtout pas des variables globales. Je te parle de paramètres à ta fonction animFleche().

    Suggestion d'appel :

    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    animFleche({
        fleche1 : '#fleche1',
        fleche2 : '#fleche2',
        fleche3 : '#fleche3',
        fleche4 : '#fleche4',
    });

    Comme ça tu apprendras aussi à manipuler le JSON, même notation sur laquelle est basé une partie des API de jQuery.

  10. #10
    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
    Bonjour

    Un ID doit être unique ! Je vois deux divisions d'ID "acces" dans le code HTMl du message 3 !

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    setInterval(function(){
    	$("#fleche1").stop(true, true).delay(200).fadeIn(200).delay(200).fadeOut(200); // 800 + 200 = 1000
    	$("#fleche2").stop(true, true).delay(1000).fadeIn(200).delay(200).fadeOut(200); // 1000 + 600 + 200 = 1800
    	$("#fleche3").stop(true, true).delay(1800).fadeIn(200).delay(200).fadeOut(200); // 1800 + 600 + 200 = 2800
    	$("#fleche4").stop(true, true).delay(2800).fadeIn(200).delay(200).fadeOut(200); // 2800 + 600 + 200 = 3600
    }, 3600);
    stop() : http://api.jquery.com/stop/

  11. #11
    Membre chevronné
    Avatar de gwinyam
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2006
    Messages
    1 162
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 162
    Points : 2 015
    Points
    2 015
    Par défaut
    La meilleure solution à ce problème de temporisation reste pour moi ce qui est proposé par space_frog : les callbacks, comme ça chaque élément dépend du précédent.

  12. #12
    Membre du Club
    Profil pro
    Inscrit en
    Février 2011
    Messages
    253
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2011
    Messages : 253
    Points : 56
    Points
    56
    Par défaut
    j'ai compris le système du callback, cependant pour la partie :"Dans le sens où en paramètres, tu dois lui passer la liste des identifiants de tes flèches plutôt que de les écrire en dur dans ta fonction.", je n'ai malheureusement pas le temps d'appronfondir mes compétences car je suis limité dans le temps de la conception de mon site.

    merci

  13. #13
    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 gwinyam Voir le message
    La meilleure solution à ce problème de temporisation reste pour moi ce qui est proposé par space_frog : les callbacks, comme ça chaque élément dépend du précédent.
    Bonsoir

    Les fonctions de rappel sont une solution, mais comme souvent en jQuery pas la seule.

    J'ai bien entendu testé le code que je propose et plus de 5 minutes.

    Avec ce code je voulais attirer l'attention sur le soin à mettre dans le choix et le calcul de la temporisation.

  14. #14
    Membre chevronné
    Avatar de gwinyam
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2006
    Messages
    1 162
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mai 2006
    Messages : 1 162
    Points : 2 015
    Points
    2 015
    Par défaut
    Ce dont je ne doute pas une minute commençant à connaître l'expert qui réside en toi.

    artenis, tu peux sans problème faire confiance à la solution proposée par danielhagnoul. Certes j'insiste sur le callback qui pour moi est une façon de penser, de mon point de vue, plus claire, mais il n'empêche que sa méthode reste bonne, simple et claire.

Discussions similaires

  1. [Plugin] Utiliser plusieurs fois je même jqgrid dans une page
    Par Christophe Charron dans le forum jQuery
    Réponses: 0
    Dernier message: 06/10/2012, 17h26
  2. Réponses: 5
    Dernier message: 03/07/2012, 16h45
  3. Utiliser plusieurs fois une même fonction
    Par ledisciple dans le forum Langage
    Réponses: 20
    Dernier message: 13/02/2010, 12h47
  4. Réponses: 3
    Dernier message: 21/08/2008, 22h30
  5. Utiliser plusieurs fois le même composant
    Par Ren97 dans le forum Composants VCL
    Réponses: 6
    Dernier message: 01/03/2008, 01h49

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