Making Your Footer Stay Put With CSS
One problem I run into pretty frequently when coding a site in to XHTML and CSS is making my footer dock to the bottom of the screen. It’s especially annoying if you have a page that’s short on content and the footer, which happens to be a different color that the body background doesn’t stay at the bottom of the browser window. I can hear you say, “But why don’t you just do a fixed position on it. That’s easy enough.” True, but if you do that then it’s always at the bottom of the screen no matter how tall the window is. So if I have a page with a lot of content that footer shouldn’t show up until the content is done. How do we fix this? Let me show you. Here’s what the problem looks like:

This tutorial assumes a few things: 1. That you know basic HTML formatting, and 2. That you have a pretty good understanding of CSS.
So first we need to make sure that everything except the footer is inside a container div. So your code would look something like this:
<div id="container">
<div id="header">Header</div>
<div id="nav">
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">Page 1</a></li>
<li><a href="#">Page 2</a></li>
</ul>
</div>
<div id="content">Content Here.</div>
</div><!—End Container—>
<div id="footer">Footer Here.</div>
Now that you’ve got your basic HTML set up, let’s head over to the CSS and see what we need to do there to get it to work. First, we want to give the html and body tags a height of 100%:
html, body {
height: 100%;
}
Next, we need to set the container div to position:relative, min-height: 100% and negative margin the bottom the height of the footer. What? A fixed height footer you say? Yes, I haven’t quite figured out the best way to do it otherwise:
#container {
min-height: 100%;
margin-bottom: -330px;
position: relative;
}
Now, onto the footer. Make sure the height on the footer matches the height of the negative margin on the container and set the position to relative:
#footer {
height: 330px;
position: relative;
}
What’s that? Yes, I know it doesn’t work yet. There’s still a bit of magic to be done. See it turns out we need a div to help separate the footer from the container. We’re going to call it clearfooter. So jump back to your HTML and add the div class right inside the closing div of the container. That’s very important. Inside the closing div:
<div id="container">
<div id="header">Header</div>
<div id="nav">
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">Page 1</a></li>
<li><a href="#">Page 2</a></li>
</ul>
</div>
<div id="content">Content Here.</div>
<div class="clearfooter"></div>
</div><!—End Container—>
<div id="footer">Footer Here.</div>
Head back over to your CSS file and add this to the clearfooter div. Notice the height again:
.clearfooter {
height: 330px;
clear: both;
}
Alright! So for those of us using browsers that aren’t stupid, this should work great. But 80% of use that one browser that is stupid, our friend Internet Explorer 6. Thankfully, it’s a pretty simple fix. I know, how often does that happen? First of all, you should know that IE7 should work fine with what we’ve done up to this point. So all we need is an IE6 specific “hack.” In your header where you’re calling your external stylesheet put this:
<!—[if lt IE 7]> <link rel="stylesheet" type="text/css" href="ie6.css" /> <![endif]—>
This is a conditional statement for IE6 so it will load the CSS file only in that browser. In the CSS file, all you have to put is:
#container {
height: 100%;
}
So there you have it! This works in IE 6 and 7, Firefox and Safari 2 and 3. I hope you’ve found this a useful tool in your CSS arsenal. If you know a better way, please let us know in the comments!

Update: Sorry guys, we had to turn off comments. Too much spam :(
.(JavaScript must be enabled to view this email address)
Apr 22, 2008
.(JavaScript must be enabled to view this email address)
Apr 22, 2008
3
.(JavaScript must be enabled to view this email address)
Apr 22, 2008
4
aronil
Apr 22, 2008
5
Kevin
Apr 22, 2008
6
Dan Philibin
Apr 26, 2008
7
.(JavaScript must be enabled to view this email address)
Apr 27, 2008
8
.(JavaScript must be enabled to view this email address)
May 19, 2008
.(JavaScript must be enabled to view this email address)
May 20, 2008
10
.(JavaScript must be enabled to view this email address)
May 24, 2008
.(JavaScript must be enabled to view this email address)
May 26, 2008
12
.(JavaScript must be enabled to view this email address)
May 26, 2008
.(JavaScript must be enabled to view this email address)
May 27, 2008
14
.(JavaScript must be enabled to view this email address)
May 27, 2008
.(JavaScript must be enabled to view this email address)
May 27, 2008
16
Meet Women
May 28, 2008
17
Kichigai-san
Jun 11, 2008
18
jim
Jun 11, 2008
.(JavaScript must be enabled to view this email address)
Jun 12, 2008
20
jim
Jun 12, 2008
.(JavaScript must be enabled to view this email address)
Jun 13, 2008
22
.(JavaScript must be enabled to view this email address)
Jun 15, 2008
23
.(JavaScript must be enabled to view this email address)
Jun 21, 2008
.(JavaScript must be enabled to view this email address)
Jun 21, 2008
25
tasarhane
Jun 27, 2008