Centering Mixin - Trik CSS

Anonim

Dengan asumsi elemen induk memiliki position: relative;, keempat properti ini akan memusatkan elemen anak baik secara horizontal maupun vertikal di dalam, tidak peduli berapa lebar tinggi keduanya.

@mixin centerer ( position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); )
.parent ( position: relative; ) .child ( @include centerer; )

Lihat Pen Centerer Mixin oleh Chris Coyier (@chriscoyier) di CodePen.

Meskipun berhati-hatilah jika elemen turunan yang dipusatkan lebih tinggi dari induk, bagian atas bisa terpotong.

Pelamun

Jika Anda ingin dapat memusatkan hanya dalam satu arah…

@mixin centerer($horizontal: true, $vertical: true) ( position: absolute; @if ($horizontal and $vertical) ( top: 50%; left: 50%; transform: translate(-50%, -50%); ) @else if ($horizontal) ( left: 50%; transform: translate(-50%, 0); ) @else if ($vertical) ( top: 50%; transform: translate(0, -50%); ) )

Lihat Pen yybgZd oleh Chris Coyier (@chriscoyier) di CodePen.