Maison > interface Web > tutoriel CSS > Comment limiter les limites de valeur CSS de l'animation de défilement de fenêtre ?

Comment limiter les limites de valeur CSS de l'animation de défilement de fenêtre ?

Patricia Arquette
Libérer: 2024-11-11 20:18:03
original
654 Les gens l'ont consulté

How to Limit CSS Value Limits of Window Scrolling Animation?

Limitation des limites de valeurs CSS de l'animation de défilement de fenêtre

Dans ce scénario, un utilisateur rencontre un problème où un élément de carte glisse pendant le défilement en bas de la page. Cependant, la carte continue de défiler indéfiniment, empêchant l'utilisateur d'atteindre le bas de la page en raison de la présence d'un pied de page.

Le but est de limiter le défilement des champs

représentant la carte lorsqu'elle atteint le bas d'un autre
de taille dynamique.

Le code JavaScript fourni anime la carte pour qu'elle se déplace lorsque l'utilisateur fait défiler :

<pre class="brush:php;toolbar:false">$(function() {

    var $sidebar   = $("#map"),
        $window    = $(window),
        offset     = $sidebar.offset(),
        topPadding = 15;

    $window.scroll(function() {
        if ($window.scrollTop() > offset.top) {
            $sidebar.stop().animate({
                marginTop: $window.scrollTop() - offset.top + topPadding
            });
        }
        else {
            $sidebar.stop().animate({
                marginTop: 0
            });
        }
    });
});
Copier après la connexion

Résoudre le problème

L'utilisation de la méthode animate() dans la fonction de défilement n'est pas recommandée car elle peut entraîner des conflits en raison de changements continus dans la valeur de défilement, empêchant jQuery d'effectuer des animations répétitives. La fonction stop() à elle seule pourrait ne pas résoudre entièrement le problème.

Au lieu de cela, il est recommandé d'utiliser la méthode CSS. Voici un exemple :

<pre class="brush:php;toolbar:false">$(window).scroll(function() {
    var scrollVal = $(this).scrollTop();
    if ( scrollVal > offset.top) {
        $sidebar.css({
           'margin-top': (($window.scrollTop() - offset.top) + topPadding) + 'px'
                       //added +'px' here to prevent old internet explorer bugs
        });
    } else {
        $sidebar.css({'margin-top':'0px'});
    }
});
Copier après la connexion

De plus, évitez d'utiliser plusieurs instructions if else dans vos calculs, car cela peut également provoquer des conflits.

Approche alternative

Pour les scénarios où l'objectif est de fixer un élément de navigation à une position de défilement spécifique, envisagez l'approche suivante :

<pre class="brush:php;toolbar:false">$(document).ready(function() {
   $(window).scroll(function() {
       var headerH = $('.header').outerHeight(true);
      //this will calculate header's full height, with borders, margins, paddings
       console.log(headerH);
       var scrollVal = $(this).scrollTop();
        if ( scrollVal > headerH ) {
        //when scroll value reach to your selector
            $('#subnav').css({'position':'fixed','top' :'0px'});
        } else {
            $('#subnav').css({'position':'static','top':'0px'});
        }
    });
 });
Copier après la connexion

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal