CSS Layout, который использует высоту 100% - PullRequest
1 голос
/ 15 июня 2009

Ребята, у меня есть CSS-макет, который я использую, который имеет верхний и нижний колонтитулы и боковую панель слева. Это прекрасно работает, но единственная проблема заключается в том, что я хотел бы, чтобы боковая панель и нижний колонтитул расширялись до нижней части экрана, если не хватает контента для заполнения основного контента. Как мне сделать это в CSS? Я разместил здесь CSS, чтобы вы могли видеть, с чем я работаю:

<style type="text/css">
    body
    {
        font: 100% Verdana, Arial, Helvetica, sans-serif;
        background: #666666;
        margin: 0;
        padding: 0;
        text-align: center;
        color: #000000;
    }
    .twoColHybLtHdr #container
    {
        width: 80%;
        background: #FFFFFF;
        margin: 0 auto;
        border: 1px solid #000000;
        text-align: left;
    }
    .twoColHybLtHdr #header
    {
        background: #DDDDDD;
        padding: 0 10px;
    }
    .twoColHybLtHdr #header h1
    {
        margin: 0;
        padding: 10px 0;
    }
    .twoColHybLtHdr #sidebar1
    {
        float: left;
        width: 8em;
        background: #EBEBEB;
        padding: 15px 0;
    }
    .twoColHybLtHdr #sidebar1 h3, .twoColHybLtHdr #sidebar1 p
    {
        margin-left: 10px;
        margin-right: 10px;
    }
    .twoColHybLtHdr #mainContent
    {
        margin: 0 20px 0 9em;
    }
    .twoColHybLtHdr #footer
    {
        padding: 0 10px;
        background: #DDDDDD;
    }
    .twoColHybLtHdr #footer p
    {
        margin: 0;
        padding: 10px 0;
    }
    .fltrt
    {
        float: right;
        margin-left: 8px;
    }
    .fltlft
    {
        float: left;
        margin-right: 8px;
    }
    .clearfloat
    {
        clear: both;
        height: 0;
        font-size: 1px;
        line-height: 0px;
    }
</style>

И пример того, как его использовать:

<div id="container">
    <div id="header" style="text-align: center"> Header goes here </div>
    <div id="sidebar1">Sidebar is here</div>
    <div id="mainContent">Main Content here</div>
    <br class="clearfloat" />
    <div id="footer">Footer Here</div>
</div>

Ответы [ 4 ]

1 голос
/ 15 июня 2009

Это можно сделать, используя display:table со 100% высотой, но, естественно, IE тоже не поддерживает это. Я часто делаю макеты таблиц, используя div с таблицами имен классов, tr и td, а затем заставляю IE заменить эти классы эквивалентным тегом. Таким образом, я обхожу весь стол как дебаты по макету. Если вас не волнует семантика, вы всегда можете игнорировать пуристов и делать подобные вещи с настоящими таблицами. Быть CSS-пуристом - это одно, но это дорогая религия, когда браузер с самой большой долей рынка - устаревший продукт с технологией 90-х годов.

1 голос
/ 15 июня 2009

взгляните на http://ryanfait.com/sticky-footer/ вам нужно будет немного изменить свой код, поскольку весь контент, кроме нижнего колонтитула, должен находиться в элементе-оболочке Джош

1 голос
/ 15 июня 2009

Оформить заказ липкими колонтитулами

http://ryanfait.com/sticky-footer/ http://www.cssstickyfooter.com/

<div id="wrap">

    <div id="main" class="clearfix">

    </div>

</div>

<div id="footer">

</div>

и

* {margin:0;padding:0;} 



html, body, #wrap {height: 100%;}

body > #wrap {height: auto; min-height: 100%;}

#main {padding-bottom: 150px;}  /* must be same height as the footer */

#footer {position: relative;
    margin-top: -150px; /* negative value of footer height */
    height: 150px;
    clear:both;} 

/* CLEAR FIX*/
.clearfix:after {content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden;}
.clearfix {display: inline-block;}
/* Hides from IE-mac \*/
* html .clearfix { height: 1%;}
.clearfix {display: block;}
/* End hide from IE-mac */

Вид дубликата CSS: фиксированный снизу и по центру

0 голосов
/ 15 июня 2009

Вам следует взглянуть на min-height CSS-свойство , однако будьте осторожны, поскольку оно не поддерживается корректно во всех браузерах (особенно IE .. кто-нибудь)

Вы также можете проверить CSS хаки минимальной высоты в Google

...