Reputation: 3411
First off, here's a .js fiddle: http://jsfiddle.net/B6DSv/
The issue I am having is with my .css:
nav {
overflow: hidden; /*THIS LINE*/
background-color: #004b98;
width: 100%;
margin: 0;
padding: 0;
}
and here:
<nav>
<ul>
<li><a href="index.html">Home</a>
<ul>
<li><a href="#">teadsfasdfadsst</a></li>
</ul>
</li>
<li><a href="#">Gallery</a></li>
<li><a href="#">Map</a></li>
</ul>
</nav>
If I take off overflow: hidden;
, the dropdown works... But my background is taken off.
Upvotes: 5
Views: 4712
Reputation: 22527
Clearfix will help
http://nicolasgallagher.com/micro-clearfix-hack/
.cf:before,
.cf:after {
content: " "; /* 1 */
display: table; /* 2 */
}
.cf:after {
clear: both;
}
/**
* For IE 6/7 only
* Include this rule to trigger hasLayout and contain floats.
*/
.cf {
*zoom: 1;
}
Upvotes: 1
Reputation: 240888
Since the children elements are floated (taken out of the document flow), the parent element, nav
, collapses upon itself; thus, the background isn't shown because nav
has a height of 0
.
Rather than using overflow:hidden
to fix this, just add a clearfix to the element instead:
nav:after {
content:'';
clear:both;
display:table;
}
Upvotes: 7