Maison >interface Web >js tutoriel >Comment réparer un Div en haut de l'écran lors du défilement ?

Comment réparer un Div en haut de l'écran lors du défilement ?

Susan Sarandon
Susan Sarandonoriginal
2024-11-11 22:52:02438parcourir

How to Fix a Div to the Top of the Screen on Scroll?

Fixer un Div en haut de l'écran lors du défilement

Le positionnement des éléments sur une page Web peut améliorer l'expérience utilisateur et l'organisation. Un scénario courant consiste à fixer un div en haut de l'écran lorsqu'il atteint un certain point de défilement.

Pour y parvenir, il existe plusieurs approches, dont l'une consiste à utiliser exclusivement CSS. En définissant la position de l'élément sur fixe, il restera ancré en haut de l'écran une fois qu'il aura défilé jusqu'à :

.fixedElement {
  background-color: #c0c0c0;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 100;
}

Cependant, cette approche suppose que l'élément est initialement positionné de manière absolue. Lorsque le décalage de défilement souhaité est atteint, sa position doit être modifiée en fixe et la propriété top doit être réinitialisée à zéro. Pour déterminer le décalage de défilement, JavaScript peut être utilisé pour surveiller la fonction scrollTop du document :

$(window).scroll(function(e){ 
  var $el = $('.fixedElement'); 
  var isPositionFixed = ($el.css('position') == 'fixed');
  if ($(this).scrollTop() > 200 && !isPositionFixed){ 
    $el.css({'position': 'fixed', 'top': '0px'}); 
  }
  if ($(this).scrollTop() < 200 && isPositionFixed){
    $el.css({'position': 'static', 'top': '0px'}); 
  } 
});

Dans ce script, lorsque le décalage de défilement atteint 200 pixels, l'élément passe à une position fixe en haut. de l'écran. Lorsque le décalage descend en dessous de 200 pixels, l'élément revient à sa position précédente. Cette technique permet une transition en douceur du div lorsque l'utilisateur fait défiler la page.

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!

Déclaration:
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