Создание адаптивного футера в Bootstrap 3: на дно контента

Пройдите тест, узнайте какой профессии подходите

Я предпочитаю
0%
Работать самостоятельно и не зависеть от других
Работать в команде и рассчитывать на помощь коллег
Организовывать и контролировать процесс работы

Быстрый ответ

Модель Flexbox предоставляет изящное решение для фиксации подвала страницы у нижнего края без применения position: fixed. Суть метода заключается в том, что для тега <body> задается свойство display: flex и flex-direction: column, а для основного содержимого сайта — flex-grow: 1. Это позволяет контенту занимать всё доступное пространство, тем самым притягивая подвал к нижнему краю экрана.

HTML
Скопировать код
<body style="display: flex; flex-direction: column; min-height: 100vh;">
  <main style="flex-grow: 1;">
    <!-- Здесь основное содержимое страницы -->
  </main>
  <footer>
    <!-- Здесь содержимое подвала -->
  </footer>
</body>
Кинга Идем в IT: пошаговый план для смены профессии

Детальная стратегия для для подвалов без фиксации

Настройка внешнего отступа body с учетом высоты подвала

Если применение абсолютной позиции предпочтительнее, важно установить для элемента, в котором располагается контент, нижний внешний отступ (margin-bottom), соответствующий высоте подвала.

CSS
Скопировать код
#wrapper {
  margin-bottom: -50px; /* Соответствует высоте подвала */
}
footer {
  position: absolute;
  bottom: 0;
  height: 50px; /* Точная высота подвала */
}

Максимальная адаптивность с помощью контейнеров Flexbox

Если на вашей странице присутствует излишек информации, то контейнеры Flexbox станут лучшей опцией. Установив для контейнера свойство display: flex, мы гарантируем, что тот будет корректно отображать содержимое, независимо от его объема.

CSS
Скопировать код
.container {
  display: flex;
  flex-wrap: wrap;
}

Flex контейнеры придадут подвалу адаптивность, позволив ему гибко подстраиваться под изменения в содержимом.

Динамическое управление высотой подвала

Профессиональный совет: используйте min-height с единицами vh, чтобы подвал гармонично соответствовал даже небольшому объему контента.

CSS
Скопировать код
footer {
  min-height: 10vh; /* Подберите значение на своё усмотрение */
}

Таким образом, веб-страница выглядит сбалансированно: подвал эстетично заполняет пространство, выглядит уместно и не создает впечатление избыточного размера.

Визуализация

Продумайте свою веб-страницу как прозрачный сосуд с водой, где подвал — это камушек на дне:

Markdown
Скопировать код
|📄 Содержимое страницы |
|------------------------|
|🪨 Подвал               |

Когда контента много (сравнимо с водой в сосуде), камушек (подвал) остается на дне:

Markdown
Скопировать код
|📄...📄...📄...📄|
|🪨 Подвал          |

И при недостаточном количестве контента подвал всё равно остается на дне благодаря магии CSS:

CSS
Скопировать код
html, body {
  height: 100%;
}

Подвал, словно булыжник, всегда находится внизу, удобно и надежно размещаясь, без необходимости применять фиксацию:

Markdown
Скопировать код
|📄 Содержимое страницы   |
|                         |
|🪨 Подвал                |

С правильно спроектированной страницей достигается истиное спокойствие!

Продвинутые концепции и практические приёмы

Прощай, фиксированный подвал

Динамичный контент порой несовместим с фиксированными решениями. Flexbox поможет подвалу понять, когда нужно уступить место и пропустить новый контент.

CSS
Скопировать код
body {
  display: flex;
  min-height: 100vh;
  flex-direction: column;
}
main {
  flex-grow: 1; /* "Я должен расти," подчеркивает основное содержимое. */
}

Выглядим хорошо с инвертированными цветами

Хотите добавить подвалу стильности в духе Джеймса Бонда? Воспользуйтесь классом navbar-inverse от Bootstrap для мгновенной смены дизайна.

HTML
Скопировать код
<footer class="navbar-inverse"> <!-- Подвал в стиле спецагента -->
  <!-- Содержание подвала -->
</footer>

Практическое применение

Позаимствуйте идеи из рабочих примеров при воплощении этих концепций в жизнь. Они были успешно протестированы в реальных условиях и демонстрировали свою эффективность в работе по вёрстке.

Полезные материалы

  1. Sticky Footer Template for Bootstrap — официальное руководство по созданию стики-подвала в Bootstrap.
  2. Sticky Footer, Five Ways | CSS-Tricks — пять способов надёжной фиксации подвала.
  3. A Complete Guide to Flexbox | CSS-Tricks — полное руководство по Flexbox, включая решение для прижатого подвала.
  4. css – Flushing footer to bottom of the page, twitter bootstrap – Stack Overflow — собрание решений и советов по вёрстке подвалов в Bootstrap от сообщества Stack Overflow.
  5. Just a moment... — рабочий пример стики-подвала в Bootstrap, демонстрирующий практическую реализацию.