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 :

Suite d'événements jQuery


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Invité
    Invité(e)
    Par défaut Suite d'événements jQuery
    Bonjour.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
     
    menu.addEventListener('click', function() {
    		$('#welcome').dequeue(true).animate({height: 'toggle', opacity: '0'},300);
    		document.getElementById('menu').setAttribute('style','display: block');
    		//$('#book').css({display: 'block'});
    }, false);
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
     
    <div id="welcome">Accueil</div>
    <div id="menu">Menu</div>
    Je ne comprends pas ce qu'il y a de mauvais avec ce code Javascript. Je veux afficher la div #menu, dont le display est défini à none dans le code CSS, après l'effacement de la div #welcome. J'ai essayé un code alternatif (en commentaire).

    Sauriez-vous comment faire ?

    Merci.

  2. #2
    Rédacteur
    Avatar de Macmillenium
    Homme Profil pro
    Développeur front-end
    Inscrit en
    Mars 2008
    Messages
    2 333
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 39
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Développeur front-end
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Mars 2008
    Messages : 2 333
    Par défaut
    Code javascript : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    $('#welcome').click(function() {
    		$('#welcome').dequeue(true).animate({height: 'toggle', opacity: '0'},300);
    		$('#menu').css('display','block');
    });

  3. #3
    Invité
    Invité(e)
    Par défaut
    Ca ne change rien de mon côté, j'avais déjà essayé cette syntaxe.

    En fait, quand je crée des exemples tout simples (comme ci-dessous) dans une page vierge, de multiples combinaisons de jQuery avec le DOM-2 fonctionnent.

    Le problème, c'est que sur ma page web, ça coince.

    Par exemple, avec le code suivant, je suis obligé de cliquer deux fois sur la div #menu pour que les fonctions soient exécutées:
    - une première fois pour ramener la div #content à 200px et fixer son opacité à 50%
    - une deuxième fois pour colorer en bleu le texte de la div #content :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    menu = document.getElementById('menu');
    content = document.getElementById('content');
     
    menu.addEventListener('click', function() {
    		$('#content').animate({height: '200px', opacity: '0.5'},200,function() {$('#content').css({color: 'blue'});});
    		}, false);
    J'ai essayé avec d'autres codes, comme celui-ci :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
     
    $('#menu').click(function() {
    		$('#content').animate({height: '200px', opacity: '0.5'},200);
    		$('#content').css('color', 'blue');
    });
    En les utilisant sur des pages vierges, ça fonctionne. Le problème ne semble pas venir d'un conflit entre DOM-2 et jQuery.

    Est-ce que vous avez déjà eu ce type de souci ? D'où cela peut provenir dans une page web?
    [je ne fournis volontairement pas mon code, il est beaucoup trop long]

  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 : 75
    Localisation : Belgique

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

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

    Difficile de comprendre le problème sans le vrai code puisque les codes de tests ne reproduisent pas votre problème. Le mieux serait de fournir un lien vers votre page de test.

    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
    Invité
    Invité(e)
    Par défaut
    J'ai compris hier soir d'où venait mon problème grâce à la réponse d'un membre sur un autre sujet, dans la partie Javascript.
    Lire cette réponse.

    J'utilisais, en mode debug, document.body.innerHTML += 'texte...' au lieu de manipuler correctement le DOM.

    Depuis, j'ai enlevé tous les innerHTML qui portaient sur le body (et même d'autres), et ça fonctionne.

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

Discussions similaires

  1. remplir une combo suite à un évènement ajax avec dwr
    Par coco-sup dans le forum Struts 1
    Réponses: 6
    Dernier message: 23/01/2013, 14h48
  2. Fermer une fenêtre suite à un évènement
    Par brazilia28 dans le forum Général JavaScript
    Réponses: 40
    Dernier message: 07/02/2007, 17h05
  3. [VBA Excel] Associer N macros à N boutons suite à un événement
    Par Vorillyan dans le forum Macros et VBA Excel
    Réponses: 12
    Dernier message: 24/11/2006, 08h46
  4. Fonction activé suite à un événement réalisé "pendant" une seconde!
    Par Martyin dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 28/10/2006, 18h45
  5. Réponses: 5
    Dernier message: 28/02/2006, 09h44

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