Précédent   Forum des professionnels en informatique > Webmasters - Développement Web > JavaScript > Bibliothèques & Frameworks > jQuery
jQuery Forum d'entraide sur le framework jQuery. Avant de poster : Tutoriels jQuery, FAQ jQuery, Tous les tutoriels JavaScript, Toutes les FAQ JavaScript
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 15/06/2011, 01h23   #1
Membre régulier
 
Avatar de kéraunos
 
Homme
Inscription : janvier 2005
Messages : 157
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations forums :
Inscription : janvier 2005
Messages : 157
Points : 71
Points : 71
Par défaut Suite d'événements jQuery

Bonjour.

Code :
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 :
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.
kéraunos est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2011, 11h14   #2
Rédacteur/Modérateur
 
Avatar de Macmillenium
 
Homme
Inscription : mars 2008
Messages : 2 288
Détails du profil
Informations personnelles :
Sexe : Homme
Âge : 26
Localisation : France, Sarthe (Pays de la Loire)

Informations professionnelles :
Secteur : High Tech - Produits et services télécom et Internet

Informations forums :
Inscription : mars 2008
Messages : 2 288
Points : 3 205
Points : 3 205
Code javascript :
1
2
3
4
5
 
$('#welcome').click(function() {
		$('#welcome').dequeue(true).animate({height: 'toggle', opacity: '0'},300);
		$('#menu').css('display','block');
});
__________________
Je ne réponds pas aux questions techniques par MP.
Macmillenium est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2011, 16h31   #3
Membre régulier
 
Avatar de kéraunos
 
Homme
Inscription : janvier 2005
Messages : 157
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations forums :
Inscription : janvier 2005
Messages : 157
Points : 71
Points : 71
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 :
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 :
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]
kéraunos est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 15/06/2011, 21h50   #4
Rédacteur
 
Avatar de danielhagnoul
 
Homme Daniel Hagnoul
Étudiant perpétuel
Inscription : février 2009
Messages : 3 221
Détails du profil
Informations personnelles :
Nom : Homme Daniel Hagnoul
Âge : 61
Localisation : Belgique

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

Informations forums :
Inscription : février 2009
Messages : 3 221
Points : 6 767
Points : 6 767
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.
__________________

FAQ jQuery

Mon cahier d’exercices sur jQuery & Co

Si un message vous a aidé ou vous semble pertinent, votez pour lui !
danielhagnoul est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 16/06/2011, 15h05   #5
Membre régulier
 
Avatar de kéraunos
 
Homme
Inscription : janvier 2005
Messages : 157
Détails du profil
Informations personnelles :
Sexe : Homme
Localisation : France

Informations forums :
Inscription : janvier 2005
Messages : 157
Points : 71
Points : 71
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.
kéraunos est déconnecté   Envoyer un message privé Réponse avec citation 10
Réponse Proposer ce sujet en actualité Cette discussion est résolue.
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 05h26.


 
 
 
 
Partenaires

Hébergement Web