3 Ways to Center A Div with CSS

In this tutorial, we'll explore three different ways to horizontally and vertically center a div inside its parent element with CSS.

CHILD

1. Flex Item

This method sets all child element margins to auto, which evenly distributes space on all sides of the element and centers it horizontally and vertically within its container.

.parent {
display: flex;
}

.child {
margin: auto;
}

2. Flexbox

This method utilizes flexbox to center the child element horizontally and vertically within its container. The CSS rules in this example apply to the parent element only. The justify-content property centers the div horizontally and the align-items property centers the div vertically.

.parent {
display: flex;
justify-content: center;
align-items: center;
}

3. Absolute Positioning & Transform

This method creates an absolute position for the element at 50% from the top and left of its container. The transform property with the translate function shift the element back 50% of its width and height, effectively centering itself both horizontally and vertically. Setting the parent container to relative positioning ensures that the child element stays within its boundary.

.parent {
position: relative;
}

.child {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}

Conclusion

These are three examples illustrating various ways to center a div element using CSS. Every web application is different, so choose the one that works best for you.

Written by: Josh Rowe

Created: July 08, 2023