首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >溢出隐藏隐藏下拉,但删除溢出隐藏隐藏导航背景。

溢出隐藏隐藏下拉,但删除溢出隐藏隐藏导航背景。
EN

Stack Overflow用户
提问于 2014-05-08 22:02:16
回答 2查看 3.8K关注 0票数 4

首先,这里有一个.js小提琴:http://jsfiddle.net/B6DSv/

我遇到的问题是我的.css:

代码语言:javascript
复制
nav {
    overflow: hidden; /*THIS LINE*/
    background-color: #004b98;
    width: 100%;
    margin: 0;
    padding: 0;
}

在这里:

代码语言:javascript
复制
<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;,下垂就能工作了.但我的背景已经消失了。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-05-08 22:04:18

由于子元素被浮动(从文档流中取出),父元素nav就会折叠到自己身上;因此,由于nav的高度为0,所以没有显示背景。

与其使用overflow:hidden来修复这个问题,不如将一个clearfix添加到元素中:

Updated Example

代码语言:javascript
复制
nav:after {
    content:'';
    clear:both;
    display:table;
}
票数 6
EN

Stack Overflow用户

发布于 2014-05-08 22:07:41

Clearfix会帮上忙的

http://nicolasgallagher.com/micro-clearfix-hack/

http://jsfiddle.net/B6DSv/1/

代码语言:javascript
复制
.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;
}
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/23553363

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档