Maison > interface Web > tutoriel CSS > Comment puis-je corriger un élément sur l'axe X uniquement en CSS et JavaScript ?

Comment puis-je corriger un élément sur l'axe X uniquement en CSS et JavaScript ?

Linda Hamilton
Libérer: 2024-12-06 10:39:15
original
430 Les gens l'ont consulté

How Can I Fix an Element to the X-Axis Only in CSS and JavaScript?

Positionnement d'un élément fixé sur l'axe X uniquement

En CSS, la propriété position permet de contrôler le positionnement d'un élément sur la page. Par défaut, les éléments sont positionnés comme « statiques », ce qui signifie qu'ils sont placés en fonction du flux de la page. Cependant, vous pouvez utiliser d'autres valeurs pour positionner les éléments plus précisément.

Pour fixer un élément sur l'axe des x uniquement, vous pouvez utiliser la position fixe. Cela verrouillera la position de l'élément par rapport à la fenêtre d'affichage, de sorte qu'il ne se déplacera pas horizontalement même lorsque la page défile.

#element {
  position: fixed;
  top: 0;
  bottom: 0;
}
Copier après la connexion

Cependant, l'utilisation d'un positionnement fixe sur un seul axe peut entraîner le chevauchement de l'élément avec d'autres contenus sur la page lorsqu'elle défile verticalement. Pour éviter cela, vous pouvez utiliser JavaScript pour ajuster dynamiquement la position de l'élément sur l'axe Y lorsque la page défile.

Solution JavaScript

En utilisant jQuery, vous pouvez attachez un écouteur d'événement de défilement à la fenêtre et mettez à jour la position supérieure de l'élément en conséquence.

$(window).scroll(function() {
  $('#element').css('top', $(this).scrollTop());
});
Copier après la connexion

Cela garantira que l'élément reste fixé sur l'axe des x tout en faisant défiler verticalement.

Solution CSS

Une autre méthode pour obtenir ce comportement uniquement avec CSS consiste à utiliser transform: translate(). Cette fonction de transformation peut être appliquée à un élément pour le déplacer verticalement sans affecter sa position sur l'axe des x.

#element {
  position: fixed;
  left: 15px;
  transform: translate(0, -$(window).scrollTop());
}
Copier après la connexion

Cette approche empêchera également l'élément de chevaucher d'autres contenus lors de son défilement.

Solution mise à jour

Comme suggéré par @PierredeLESPINAY, pour que le script prenne en charge les modifications dans le CSS sans avoir à le faire recodez-les, vous pouvez récupérer la position initiale gauche de l'élément en utilisant parseInt($("#element").css('left')) et l'utiliser dans le script comme décalage.

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