100% минимальная высота CSS макет - PullRequest
155 голосов
/ 24 августа 2008

Каков наилучший способ создать элемент с минимальной высотой 100% в широком диапазоне браузеров? В частности, если у вас есть макет с верхним и нижним колонтитулами фиксированной высоты, как сделать так, чтобы средняя часть содержимого заполняла 100% пространства между ними, а нижний колонтитул был зафиксирован в нижней части?

Ответы [ 13 ]

110 голосов
/ 24 августа 2008

Я использую следующее: CSS Layout - 100% высота

Минимальная высота

Элемент #container этой страницы имеет минимальную высоту 100%. Тот Кстати, если контент требует больше высоты, чем обеспечивает область просмотра, высота #content заставляет #container также становиться длиннее. Возможные столбцы в #content можно затем визуализировать с помощью фона изображение на #container; div не являются ячейками таблицы, и вам не нужно (или хочу) физические элементы для создания такого визуального эффекта. Если вы еще не убежден; думать, шаткие линии и градиенты вместо прямые и простые цветовые решения.

Относительное позиционирование

Поскольку #container имеет относительную позицию, #footer всегда будет оставаться в его основании; так как упомянутая выше минимальная высота не мешает #container от масштабирования, это будет работать, даже если (или, особенно, когда) #content заставляет #container становиться длиннее.

Перетяжка дно

Так как он больше не находится в нормальном потоке, нижнее заполнение #content теперь предоставляет место для абсолютного #footer. Это дополнение включен в высоту прокрутки по умолчанию, так что нижний колонтитул будет никогда не перекрывайте вышеуказанное содержимое.

Немного измените размер текста или измените размер окна браузера, чтобы проверить это раскладка.

html,body {
    margin:0;
    padding:0;
    height:100%; /* needed for container min-height */
    background:gray;

    font-family:arial,sans-serif;
    font-size:small;
    color:#666;
}

h1 { 
    font:1.5em georgia,serif; 
    margin:0.5em 0;
}

h2 {
    font:1.25em georgia,serif; 
    margin:0 0 0.5em;
}
    h1, h2, a {
        color:orange;
    }

p { 
    line-height:1.5; 
    margin:0 0 1em;
}

div#container {
    position:relative; /* needed for footer positioning*/
    margin:0 auto; /* center, not in IE5 */
    width:750px;
    background:#f0f0f0;

    height:auto !important; /* real browsers */
    height:100%; /* IE6: treaded as min-height*/

    min-height:100%; /* real browsers */
}

div#header {
    padding:1em;
    background:#ddd url("../csslayout.gif") 98% 10px no-repeat;
    border-bottom:6px double gray;
}
    div#header p {
        font-style:italic;
        font-size:1.1em;
        margin:0;
    }

div#content {
    padding:1em 1em 5em; /* bottom padding for footer */
}
    div#content p {
        text-align:justify;
        padding:0 1em;
    }

div#footer {
    position:absolute;
    width:100%;
    bottom:0; /* stick to bottom */
    background:#ddd;
    border-top:6px double gray;
}
div#footer p {
    padding:1em;
    margin:0;
}

У меня отлично работает.

30 голосов
/ 30 марта 2011

Чтобы установить произвольную высоту, заблокированную где-то:

body, html {
  height: 100%;
}
#outerbox {
  width: 100%;
  position: absolute; /* to place it somewhere on the screen */
  top: 130px;         /* free space at top */
  bottom: 0;          /* makes it lock to the bottom */
}
#innerbox {
  width: 100%;
  position: absolute;				
  min-height: 100% !important; /* browser fill */
  height: auto;                /*content fill */
}
<div id="outerbox">
  <div id="innerbox"></div>
</div>
22 голосов
/ 15 августа 2015

Вот еще одно решение, основанное на vh или viewpoint height, для получения подробной информации посетите CSS-единицы . Он основан на этом решении , в котором вместо этого используется flex.

* {
    /* personal preference */
    margin: 0;
    padding: 0;
}
html {
    /* make sure we use up the whole viewport */
    width: 100%;
    min-height: 100vh;
    /* for debugging, a red background lets us see any seams */
    background-color: red;
}
body {
    /* make sure we use the full width but allow for more height */
    width: 100%;
    min-height: 100vh; /* this helps with the sticky footer */
}
main {
    /* for debugging, a blue background lets us see the content */
    background-color: skyblue;
	min-height: calc(100vh - 2.5em); /* this leaves space for the sticky footer */
}
footer {
    /* for debugging, a gray background lets us see the footer */
    background-color: gray;
	min-height:2.5em;
}
<main>
    <p>This is the content. Resize the viewport vertically to see how the footer behaves.</p>
    <p>This is the content.</p>
    <p>This is the content.</p>
    <p>This is the content.</p>
    <p>This is the content.</p>
    <p>This is the content.</p>
    <p>This is the content.</p>
    <p>This is the content.</p>
    <p>This is the content.</p>
    <p>This is the content.</p>
</main>
<footer>
    <p>This is the footer. Resize the viewport horizontally to see how the height behaves when text wraps.</p>
    <p>This is the footer.</p>
</footer>

Единицами измерения являются vw, vh, vmax, vmin. По сути, каждая единица равна 1% от размера области просмотра. Таким образом, при изменении области просмотра браузер вычисляет это значение и корректирует его соответствующим образом.

Вы можете найти больше информации здесь:

В частности:

1vw (viewport width) = 1% of viewport width
1vh (viewport height) = 1% of viewport height
1vmin (viewport minimum) = 1vw or 1vh, whatever is smallest
1vmax (viewport minimum) = 1vw or 1vh, whatever is largest
15 голосов
/ 27 августа 2008

Ответ kleolb02 выглядит довольно хорошо. другим способом было бы сочетание липкого нижнего колонтитула и минимальной высоты хака

6 голосов
/ 28 августа 2013

Чтобы min-height правильно работал с процентами, при этом наследуя его родительский узел min-height, уловка была бы в том, чтобы установить высоту родительского узла на 1px, и тогда дочерний min-height будет работать правильно.

Демонстрационная страница

6 голосов
/ 04 сентября 2008

Чистое решение CSS (#content { min-height: 100%; }) будет работать во многих случаях, но не во всех - особенно в IE6 и IE7.

К сожалению, вам нужно прибегнуть к решению JavaScript, чтобы получить желаемое поведение. Это можно сделать, рассчитав нужную высоту для вашего контента <div> и установив ее как свойство CSS в функции:

function resizeContent() {
  var contentDiv = document.getElementById('content');
  var headerDiv = document.getElementById('header');
  // This may need to be done differently on IE than FF, but you get the idea.
  var viewPortHeight = window.innerHeight - headerDiv.clientHeight;
  contentDiv.style.height = 
    Math.max(viewportHeight, contentDiv.clientHeight) + 'px';
}

Затем вы можете установить эту функцию в качестве обработчика для событий onLoad и onResize:

<body onload="resizeContent()" onresize="resizeContent()">
  . . .
</body>
3 голосов
/ 12 октября 2012

Сначала вы должны создать div с id='footer' после вашего content div, а затем просто сделать это.

Ваш HTML должен выглядеть так:

<html>
    <body>
        <div id="content">
            ...
        </div>
        <div id="footer"></div>
    </body>
</html>

И CSS:

​html, body {
    height: 100%;   
}
#content {
    height: 100%;
}
#footer {
    clear: both;        
}
3 голосов
/ 18 апреля 2012

Я согласен с Levik, так как родительский контейнер установлен на 100%, если у вас есть боковые панели и вы хотите, чтобы они заполняли пространство для соответствия нижнему колонтитулу, вы не можете установить их на 100%, потому что они будут составлять 100 процентов от высоты родительского элемента. а также, что означает, что нижний колонтитул в конечном итоге выталкивается при использовании функции очистки.

Подумайте об этом так, если ваш заголовок имеет высоту 50px, а нижний колонтитул имеет высоту 50px, а содержимое просто встраивается в оставшееся пространство, например, 100px, а контейнер страницы составляет 100% от этого значения, его высота будет 200px , Затем, когда вы устанавливаете высоту боковой панели на 100%, она становится равной 200px, хотя она должна плотно прилегать между верхним и нижним колонтитулом. Вместо этого получается 50px + 200px + 50px, поэтому страница теперь имеет 300px, потому что боковые панели установлены на ту же высоту, что и контейнер страницы. В содержимом страницы будет большой пробел.

Я использую Internet Explorer 9, и это то, что я получаю в качестве эффекта при использовании этого 100% метода. Я не пробовал его в других браузерах, и я предполагаю, что он может работать в некоторых других вариантах. но это не будет универсальным.

2 голосов
/ 20 сентября 2013

Вероятно, самое короткое решение (работает только в современных браузерах)

Этот маленький кусочек CSS делает "the middle content part fill 100% of the space in between with the footer fixed to the bottom":

html, body { height: 100%; }
your_container { min-height: calc(100% - height_of_your_footer); }

Единственное требование - наличие нижнего колонтитула с фиксированной высотой.

Например, для этого макета:

<html><head></head><body>
  <main> your main content </main>
  </footer> your footer content </footer>
</body></html>

вам нужен этот CSS:

html, body { height: 100%; }
main { min-height: calc(100% - 2em); }
footer { height: 2em; }
2 голосов
/ 21 апреля 2010

Попробуйте это:

body{ height: 100%; }
#content { 
    min-height: 500px;
    height: 100%;
}
#footer {
    height: 100px;
    clear: both !important;
}

Элемент div ниже содержимого div должен иметь clear:both.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...