margin: auto
data:image/s3,"s3://crabby-images/6ceb2/6ceb2129acd1d18aa7ef36e695d2ebe04ae4b34d" alt="Using margin: auto for Centering in CSS"
Unlike for padding
, you can use auto
as a keyword for the margin
property value. When you use auto
, the browser tries to maximize margins as much as possible.
For example, in the case like in the illustration below,
data:image/s3,"s3://crabby-images/314b4/314b474265f3ad0729b5de43ae0fea3ac76bab30" alt="A HTML child element position without margin: auto A HTML child element position without margin: auto"
when you set margin: auto
for the child element, the auto value tries to maximize the margin for both sides. As a result, the child element is placed in the center of the parent element horizontally.
data:image/s3,"s3://crabby-images/ca520/ca52054b22a1effb2549897b5f471a4ed97ab156" alt="A HTML child element position with margin: auto A HTML child element position with margin: auto"
When you set margin-left: auto
for the child element, the auto value tries to maximize the left side of the margin. As a result, the child element is pushed to the right edge of the parent element.
data:image/s3,"s3://crabby-images/6d601/6d60160f48b8d7f8f1693b57ca1e7fb78cd53933" alt="A HTML child element position with margin-left: auto A HTML child element position with margin-left: auto"
margin: auto with Flex Box
In the regular situation, margin: auto
works only horizontally; however, when the parent element is set as a Flex Box, the auto
keyword works for both horizontal and vertical dimensions. We'll explain how margin: auto
works with Flex Box later.