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: flex
justify-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: flex
justify-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 »