溢出隐藏隐藏下拉列表,但隐藏溢出隐藏导航背景

时间:2014-05-08 22:02:17

标签: html css

首先,这里是一个.j小提琴: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;,则下拉列表有效......但我的背景已被取消。

2 个答案:

答案 0 :(得分:6)

由于子元素被浮动(从文档流中取出),父元素nav会自行折叠;因此,后台未显示,因为nav的高度为0

不是使用overflow:hidden来解决此问题,而只需在元素中添加clearfix

Updated Example

nav:after {
    content:'';
    clear:both;
    display:table;
}

答案 1 :(得分:1)

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;
}