首先,这里有一个.js小提琴:http://jsfiddle.net/B6DSv/
我遇到的问题是我的.css:
nav {
overflow: hidden; /*THIS LINE*/
background-color: #004b98;
width: 100%;
margin: 0;
padding: 0;
}在这里:
<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>如果我拿掉overflow: hidden;,下垂就能工作了.但我的背景已经消失了。
发布于 2014-05-08 22:04:18
由于子元素被浮动(从文档流中取出),父元素nav就会折叠到自己身上;因此,由于nav的高度为0,所以没有显示背景。
与其使用overflow:hidden来修复这个问题,不如将一个clearfix添加到元素中:
Updated Example
nav:after {
content:'';
clear:both;
display:table;
}发布于 2014-05-08 22:07:41
Clearfix会帮上忙的
http://nicolasgallagher.com/micro-clearfix-hack/
http://jsfiddle.net/B6DSv/1/
.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;
}https://stackoverflow.com/questions/23553363
复制相似问题