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 :

Changer marginTop quand scroll


Sujet :

jQuery

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre confirmé Avatar de bouchra19
    Femme Profil pro
    Développeur multimédia
    Inscrit en
    Juin 2011
    Messages
    104
    Détails du profil
    Informations personnelles :
    Sexe : Femme

    Informations professionnelles :
    Activité : Développeur multimédia
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Juin 2011
    Messages : 104
    Par défaut Changer marginTop quand scroll
    Bonjour à tous,
    Je travaille sur un site en Drupal 7, j'ai ajouté un code jQuery pour qu'un menu dans la barre latérale change en margin-top quand on scroll à partir de 129px du haut.
    Le script marche très bien, MAIS quand je reviens en haut le menu ne revient pas à sa position originale (ça m'arrive quand je scroll avec la roulette de la souris, mais quand je scroll en cliquant sur la barre de défilement ça marche parfaitement)
    voilà le code que j'ai utilisé:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    (function($) {
        $(window).scroll(function(){
    	if  ($(window).scrollTop() >= 129){
        var fromTop = $(window).scrollTop();
        $("#block-system-navigation").css('marginTop', (fromTop - 129) + 'px');
    	}
    });
     
    })(jQuery);
    Je vous prie de m'aider, j'ai cherché sur le net mais j'ai pas trouvé la solution
    P.S: je ne peux changer la propriété css "position" parce que ça boulverse tout l'affichage

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

    Il est très difficile de comprendre et de tester un problème sans le contexte (HTML, CSS, JS), je suggère de tester :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    $( window ).on( "scroll", function(){
    	var fromTop = $( this ).scrollTop(),
    		jObj = $( "#block-system-navigation" );
     
    	if  ( fromTop >= 129){
    		jObj.css( 'marginTop', '0px' );
    	} else {
    		jObj.css( 'marginTop', '129px' );
    	}
    });

    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. [Firefox] Flash non activé quand scroll firefox
    Par Tchinkatchuk dans le forum Flash
    Réponses: 4
    Dernier message: 18/08/2009, 23h27
  2. changer largeur vertical scroll
    Par viking1404 dans le forum MXML
    Réponses: 4
    Dernier message: 08/06/2009, 23h50
  3. Réponses: 8
    Dernier message: 06/07/2006, 01h15
  4. Changer flèches du scroll
    Par Laure888 dans le forum Balisage (X)HTML et validation W3C
    Réponses: 7
    Dernier message: 04/11/2005, 16h10
  5. [JTextField]Savoir quand le contenu à changer
    Par Antunes dans le forum Composants
    Réponses: 4
    Dernier message: 25/08/2004, 14h43

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