This article shows you how to centre (or "center" if you use a different variant of English) a DIV block, whether it contains text, graphics, or a mixture of both, using standards-compliant Cascading Style Sheets (CSS). The technique is useful not just for creating pleasing designs, but also for times when you want to create a fixed width single column layout with the main content placed in the centre of the page, and not flushed to one side.
I will assume in this article that you have some basic knowledge of how to write HTML and CSS, and at the very least, know how to insert CSS code.
If you don't even have a website yet, and have arrived at this article looking for tips on designing one, please start with my article on How to Start/Create Your Own Website instead.
Let's assume that you have a div
block as follows:
At first glance, you may think that the following CSS rule will work.
However, the rule centres the text inside the box, rather than the block itself. While there are times when you may want to do this, our intention here is to centre the entire block but leave the internal contents formatted as it was before. As such, the above code is not what we want.
Instead, the standard trick for centring ("centering") a block in CSS is to do the following:
auto
.
Both steps are necessary. You cannot just set the margins to auto
without
specifying the width of the block and expect this method to work.
For example, if you want your div
block to have a width of 700 pixels, the following code will centre the block.
#content { width: 700px ; margin-left: auto ; margin-right: auto ; }
The technique works because when both margins are set to auto
,
web browsers are required by the CSS standard to give them equal width. This is why you also have
to specify the width of the DIV block, since browsers will otherwise set it to 100% of the available space.
If all the space is occupied by the block, there's no need to centre it. Centring is only relevant
if an object is smaller than the space around it.
Incidentally, the width doesn't need to be in pixels. Other units like em
or percentage will work just as well.
At the time this article was written, you can see an example of this code in action on the Fixed Width Layout Demo Page. The main body of that page has a width of 730 pixels, and is centred using the method given here, so that it appears in the middle of the browser window.
(Note: if your browser window is opened too small, or your monitor has too low a resolution, you will of course not be able to see the effect.)
The code above has been tested with IE 6 to 11, Firefox, Chrome, Vivaldi, Opera and Safari. It should work in all later browsers as well, since the newer ones tend to be standards-compliant.
Note that this article only deals with the centring of a DIV block using CSS. If you want to centre a table, and need to work around bugs in IE 6 and 7, please see my article How to Centre a Table Using CSS instead. Although that article is directed at Nvu and KompoZer users, the code itself is given in CSS and HTML so you should have no trouble following what is said. And if you want to do the same with an image, please see How to Centre an Image with CSS.
The method above is the standard technique for centring a DIV block using standards-compliant CSS. With this, you can centre your blocks without
using deprecated HTML tags like <center>
. And the code even works in buggy browsers like IE 6 and 7.
This article can be found at https://www.thesitewizard.com/css/center-div-block.shtml
Copyright © 2008-2018 by Christopher Heng. All rights reserved.
Get more free tips and articles like this,
on web design, promotion, revenue and scripting, from https://www.thesitewizard.com/.
Do you find this article useful? You can learn of new articles and scripts that are published on thesitewizard.com by subscribing to the RSS feed. Simply point your RSS feed reader or a browser that supports RSS feeds at https://www.thesitewizard.com/thesitewizard.xml. You can read more about how to subscribe to RSS site feeds from my RSS FAQ.
This article is copyrighted. Please do not reproduce or distribute this article in whole or part, in any form.
It will appear on your page as:
How to Centre a DIV Block Using CSS