Maison >interface Web >tutoriel CSS >Pourquoi « margin-left : auto » et « margin-right : auto » ne centrent-ils pas un élément avec « position : absolue » ?

Pourquoi « margin-left : auto » et « margin-right : auto » ne centrent-ils pas un élément avec « position : absolue » ?

Mary-Kate Olsen
Mary-Kate Olsenoriginal
2024-10-29 13:57:02889parcourir

Why Doesn't `margin-left: auto` and `margin-right: auto` Center an Element with `position: absolute`?

Centrage d'un élément avec CSS : positionnement absolu vs positionnement relatif

Lorsque vous essayez de centrer un élément à l'aide de CSS, vous pouvez rencontrer un problème où margin-left: auto et margin-right: auto semblent inefficaces avec position: absolue. Cependant, ces marges fonctionnent lorsque position: relative est appliquée.

Cette différence vient de la façon dont position: Absolute supprime un élément du flux normal du document et le place selon les coordonnées fournies. Dans ce contexte, définir les marges sur auto n'a aucun effet car il n'y a pas d'élément "parent" avec lequel calculer les marges relatives.

D'un autre côté, position: relative maintient la position de l'élément dans le flux normal de la page . Par conséquent, margin-left: auto et margin-right: auto peuvent être utilisés pour centrer l'élément par rapport à son élément conteneur.

Pour centrer un élément horizontalement en utilisant le positionnement absolu, vous pouvez définir la largeur de l'élément, le positionner sur les bords gauche et droit de son conteneur parent en utilisant gauche et droite, et définissez les positions supérieure et inférieure pour centrer l'élément verticalement.

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