Maison > interface Web > tutoriel CSS > Comment réaliser une expansion centrée pour un élément DIV à l'aide de transitions CSS ?

Comment réaliser une expansion centrée pour un élément DIV à l'aide de transitions CSS ?

Susan Sarandon
Libérer: 2024-10-28 14:29:30
original
399 Les gens l'ont consulté

How to Achieve Centered Expansion for a DIV Element using CSS Transitions?

Agrandissement d'un DIV à partir de son centre à l'aide de CSS

Dans cette question, nous visons à créer un effet où un div se développe à partir de son centre, plutôt que l'expansion typique du coin supérieur gauche. Bien que les transformations CSS telles que scale() puissent obtenir cet effet, elles manquent de précision en pixels et n'affectent pas la mise en page environnante.

La clé pour obtenir ce comportement réside dans la transition de la marge. En calculant une valeur de marge spécifique, nous pouvons faire agrandir le div à partir du centre sans interférer avec le flux de documents.

Options pour l'expansion centrale

Option 1 : Expansion dans l'espace réservé

<code class="css">#square {
  margin: 100px;
  transition: width 1s, height 1s, margin 1s;
}
#square:hover {
  width: 100px;
  height: 100px;
  margin: 55px;
}</code>
Copier après la connexion

Dans cette option, le div se développe dans un espace pré-réservé autour de lui. La transition de marge est calculée comme la marge initiale moins la moitié du changement de largeur/hauteur.

Option 2 : Expansion sur les éléments environnants

<code class="css">#square {
  margin: 0;
  transition: width 1s, height 1s, margin 1s;
}
#square:hover {
  width: 110px;
  height: 110px;
  margin: -50px;
}</code>
Copier après la connexion

Avec cette option, le div s'étend sur tous les éléments environnants. La transition de marge est calculée comme 0 moins la moitié du changement de largeur/hauteur.

Option 3 : Expansion sur et déplacement d'autres éléments

<code class="css">#square {
  position: relative;
  transition: width 1s, height 1s, top 1s, left 1s, margin 1s;
}
#square:hover {
  width: 110px;
  height: 110px;
  top: -50px;
  left: -50px;
  margin-right: -50px;
  margin-bottom: -50px;
}</code>
Copier après la connexion

Cette option permet au div pour étendre les éléments précédents du flux, tout en décalant les éléments suivants. Les transitions de marge sont calculées de la même manière que les options précédentes.

Considérations pour les DIV non carrés

Les options ci-dessus supposent un div carré, mais elles peuvent également être appliquées à divs non carrés avec de légers ajustements aux calculs de marge. Par exemple, un rectangle de largeur et de hauteur inégales peut faire l'objet d'une transition en utilisant des marges comme :

<code class="css">margin: -50px -100px;</code>
Copier après la connexion

En résumé, en manipulant la marge à l'aide de transitions CSS, il est possible de créer un div qui s'étend à partir de son centre, affectant la disposition environnante comme vous le souhaitez.

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