如果内容超过页面大小,如何设置div可滚动?

时间:2013-10-16 16:23:51

标签: javascript jquery html asp.net css

我有下一页:

<div id = "menu">
    Menu on the left side
</div>
<div id = "header">
    Header content of the page
</div>
<div id = "body">
    Data Data Data Data Data Data Data 
</div>
<div id = "footer">
    Additional Information
</div>

Whith下一个布局:菜单应位于左侧:

#menu{
    background: #244a7c;
    padding: 7px 23px 0 7px;
    width: 299px;
    height: 1000px;
    overflow: inherit;
    margin-left: 0px;
    display: block;
    float: left;
}
#header{
    display: inline-block;
    width: 400px;
    border-bottom: 1px solid rgb(238, 238, 238);
}

Body可以在里面有不同的数据。我的问题是:

当身体的内容超过用户页面时,我想要修复身体以外的所有div。菜单应位于左侧,标题应位于页面顶部,页脚位于底部,仅限主体应滚动。

请帮助。

谢谢!

2 个答案:

答案 0 :(得分:1)

这是2个纯CSS解决方案

不固定任何高度(页眉/页脚)或宽度(左列)。

我实际上更喜欢第二种解决方案。 (即使他的浏览器支持较少)

1 - 使用CSS技巧

这是一个完全响应的设计,适用于所有浏览器(IE10,FF,Chrome,Safari,Opera,移动浏览器)

Working Fiddle

<强> HTML:

<div class="Container">
    <div class="Header">
    </div>
    <div class="HeightTaker">
        <div class="Wrapper Container Inverse">
            <div>
                <div class="Footer">
                </div>
            </div>
            <div class="HeightTaker">
                <div class="Wrapper">
                    <div class="LeftMenu">
                    </div>
                    <div class="Content">
                    </div>
                </div>
            </div>
        </div>
    </div>
</div>

<强> CSS:

*
{
    margin: 0;
    padding: 0;
}
html, body, .Container
{
    height: 100%;
}
    .Container:before
    {
        content: '';
        height: 100%;
        float: left;
    }
.HeightTaker
{
    position: relative;
    z-index: 1;
}
    .HeightTaker:after
    {
        content: '';
        clear: both;
        display: block;
    }
.Wrapper
{
    position: absolute;
    width: 100%;
    height: 100%;
}
.Inverse, .Inverse > *
{
    -moz-transform: rotateX(180deg);
    -ms-transform: rotateX(180deg);
    -o-transform: rotate(180deg);
    -webkit-transform: rotateX(180deg);
    transform: rotateX(180deg);
}
.LeftMenu
{
    height: 100%;
    float: left;
}
.Content
{
    overflow: auto;
    height: 100%;
}

/*For demonstration only*/
p
{    
    font-size: 1.3em;
}

.Important
{
    font-weight: bolder;
    color: white;
}

body > .Container
{
    text-align: center;
}

.Header
{
    background-color: #bf5b5b;
}
.LeftMenu
{
    background-color:  #bdbe4c;
}

.Content
{
    background-color: #90adc1;
}
.Footer
{
    background-color: #b5a8b7;
}

2 - 使用Flex

这种布局也可以使用flex实现,但目前的浏览器支持是纯粹的。 这是Working Fiddle 唯一 FF,Chrome,IE10。

HTML:(更简单)

<header>
</header>
<section class="Middle">
    <div class="LeftMenu">
    </div>
    <div class="Content">
    </div>
</section>
<footer>
</footer>

<强> CSS:

*
{
    margin: 0;
    padding: 0;
}
html, body
{
    height: 100%;
    text-align: center;
}

body
{
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;

    -webkit-flex-direction: column;
    -ms-flex-direction: column;
    flex-direction: column;
}

.Middle
{    
    -webkit-flex: 1 1 auto;
    -ms-flex: 1 1 auto;
    flex: 1 1 0;

    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;

    overflow: hidden;
}

.Content
{   
    -webkit-flex: 1 1 auto;
    -ms-flex: 1 1 auto;
    flex: 1 0 0;

    overflow: auto;
}

/*For demonstration only*/
p
{    
    font-size: 1.3em;
}

.Important
{
    font-weight: bolder;
    color: white;
}

header
{
    background-color: #bf5b5b;
}
.LeftMenu
{
    background-color:  #bdbe4c;
}

.Content
{
    background-color: #90adc1;
}
footer
{
    background-color: #b5a8b7;
}

答案 1 :(得分:0)

如果您设置headerfooter&amp; menu作为固定位置的#header { position: fixed; top: 0; display: inline-block; width: 400px; border-bottom: 1px solid rgb(238, 238, 238); } #footer { position: fixed; bottom: 0; } #menu { position: fixed; left: 0; background: #244a7c; padding: 7px 23px 0 7px; width: 299px; height: 1000px; } #body { margin-left: 300px; margin-top: <header-height>; margin-bottom: <footer-height>; } 位置离开身体,它应该工作。只有身体可以滚动。

{{1}}