div之外的css div

时间:2013-07-16 05:25:36

标签: html css

很抱歉再次请求css帮助,但我真的无法得到这个。我的问题是一个子div超出了上部div的区域。我尝试使用:

display: inline-block;`

但这会让外部的div变得疯狂。

我的问题: enter image description here

有一个带有侧边栏ID的div,其中包含左侧框。这是另一个id为main的div。

HTML:

<div id="main">
            <div id="sidebar">
                <div id="box">
                    <h3>Recently Uploaded</h3>
                    <ul>
                        <li><a href="#">402 Base</a></li>
                        <li><a href="#">heli mod</a></li>
                        <li><a href="#">mw2 menu 1.14</a></li>
                        <li><a href="#">402 Base</a></li>
                        <li><a href="#">heli mod</a></li>
                        <li><a href="#">mw2 menu 1.14</a></li>
                        <li><a href="#">402 Base</a></li>
                        <li><a href="#">heli mod</a></li>
                        <li><a href="#">mw2 menu 1.14</a></li>
                        <li><a href="#">402 Base</a></li>
                    </ul>
                </div>
                             ...

的CSS:

#main
{
    width: 80%;
    height: 100%;
    background: rgb(255, 255, 255);
    background: rgba(255, 255, 255, .4);
    margin-left: auto;
    margin-right: auto;
}

#sidebar
{
    height: 100%;
    width: 20%;
    float: left;
    margin-left: 20px;
    margin-right: 20px;
    margin-bottom: 20px;
    margin-top: 60px;
}

#box
{
    /* min-width: 12em; idk if I wanted this */
    width: 100%;
    background-color: #F8F8F8;
    border: 1px solid #000;
    -moz-border-radius: 5px;
    border-radius: 5px;
    margin-bottom: 15px;
    font-family: Arial, Helvetica, sans-serif;
    display: inline-block;
}

#box p
{
    padding: 10px;
}

#box h3
{
    margin: 0;
    margin-top: 5px;
    padding-left: 10px;
    border-bottom: 1px solid #000;
    font-size: 12pt;
    font-weight:bold;
}

#box ul
{
    font-size: 10pt;
    margin: 0;
    padding: 0;
    list-style: none;
}

#box ul li
{
    width: 100%;
    height: 40px;
    line-height: 40px;
    border-bottom: 1px solid #000;
}

我能做什么? :(

3 个答案:

答案 0 :(得分:2)

一个应该跨浏览器工作且具有极佳浏览器支持的解决方案是将以下内容应用于#main div:

#main{
    ...
    overflow: hidden;
}

使用此方法会在绘制背景,边框等时强制将任何浮动元素计算到容器的高度。

答案 1 :(得分:0)

尝试将float: left;添加到#main

答案 2 :(得分:0)

试试这个:

display:table; /* TO our main ID */