CSS Centering Images
Learn how to center an image horizontally and vertically with CSS.
Center an Image Horizontally in Two Ways
1. Using margin: auto
One way to center an image horizontally on a page is to use margin: auto.
Since the <img> element is an inline element (and
margin: auto does not have any effect on inline elements) we also must
convert the image to a block element, with display: block.
In addition, we have to define a width. The
width of the image must be smaller than the width of the page.
Here is a horizontally centered image using margin: auto:
2. Using display: flex
Another way to center an image horizontally on a page is to use display: flex.
Here, we put the <img> element inside a <div> container.
We add the following CSS to the div container:
display: flexjustify-content: center(centers the image horizontally in the div container)
Then, we set a width for the image. The width of the image must be smaller than the width of the page.
Here is a horizontally centered image using display: flex:
Center an Image Vertically
display: flex is also used to center an image vertically on a page.
Let's say we have a <div> container that is 600px high.
Now we want to center the image vertically in the div container.
Here, we also put the <img> element inside a <div> container.
We add the following CSS to the div container:
display: flexjustify-content: center(centers the image horizontally in the div container)align-items: center(centers the image vertically in the div container)height: 600px(the height of the div container)
Then, we set a height for the image (must be smaller than the height of the container).
Here is a vertically centered image:
Example
div {
display: flex;
justify-content: center;
align-items: center;
height: 600px;
border: 1px solid
black;
}
img {
width: 50%;
height: 50%;
}
Try it Yourself »