Строки не заполняют высоту

Я немного поэкспериментировал с CSS Grid и попытался разработать простую веб-страницу. Я использую модуль fr, чтобы равномерно отображать мой контент и делать его отзывчивым. Столбцы создаются равномерно, чтобы заполнить пространство экрана. Но ряды, с другой стороны, не заполняют пространство. Они создаются, но не для заполнения всей высоты экрана.

Вот мой HTML:

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <meta http-equiv="X-UA-Compatible" content="ie=edge">
  <link href="style.css" type="text/css" rel="stylesheet">
  <link href="https://fonts.googleapis.com/css?family=Roboto:300,400,500,700,900" rel="stylesheet">
  <title>Name of Site</title>
</head>
<body>
  <div class="container">
    <header class="header box">
      <h1>Name</h1>
    </header>
    <nav class="info box">
      <h2>General Information</h2>
    </nav>
    <div class="right box">
      <h3>Right</h3>
    </div>
    <footer class="footer box">
      <h2>Footer</h2>
    </footer>
  </div>
</body>
</html>

Вот мой CSS-код:

/* Resets */

  body {
  margin: 0;
}

/* Typography */

h1, h2, h3 {
  font-family: 'Roboto';
  text-align: center;
  font-variant-caps: all-petite-caps;
}

ul, li, p {
  font-family: 'Roboto';
}

.box {
  color: #ffffff;
  padding: 10px 10px;
}

/* CSS Grid */
@media (min-width: 960px) {
  .container {
    display: grid;
    grid-template-areas:
      "h r"
      "i r"
      "f r"; 
    grid-template-columns: 1fr 2fr;
    grid-template-rows: 1fr 3fr 1fr;
  }
}

.header {
  grid-area: h;
  background-color: #57B8BF;
}

.info {
  grid-area: i;
  background-color: #3A7B7F;
}

.footer {
  grid-area: f;
  background-color: #1D3D40;
  color: #ffffff;
}

.right {
  grid-area: r;
  background-color: #ffffff;
  color: black;
}

Результат, который я продолжаю получать, таков:

Результат сетки CSS.

У меня есть дисплей Firefox Grid, чтобы вы могли видеть, как устроена сетка. Но на изображении я написал красным пространство, которое теперь включается при создании строк. Разве нижний колонтитул не должен быть в конце столбца?

Как мне заставить строки равномерно распределять высоту страницы так же, как это делается со столбцами?


person jdruiz    schedule 10.12.2017    source источник
comment
stackoverflow.com/a/46546152/3597276   -  person Michael Benjamin    schedule 10.12.2017


Ответы (2)


Просто отрегулируйте container и html, body до 100% высоты.

html, body {
  height: 100%;
}

.container {
  height: 100%;
}

html, body {
  height: 100%;
}

body {
  margin: 0;
}

/* Typography */

h1, h2, h3 {
  font-family: 'Roboto';
  text-align: center;
  font-variant-caps: all-petite-caps;
}

ul, li, p {
  font-family: 'Roboto';
}

.box {
  color: #ffffff;
  padding: 10px 10px;
}

/* CSS Grid */
@media (min-width: 960px) {
  .container {
    height: 100%;
    display: grid;
    grid-template-areas:
      "h r"
      "i r"
      "f r"; 
    grid-template-columns: 1fr 2fr;
    grid-template-rows: 1fr 3fr 1fr;
  }
}

.header {
  grid-area: h;
  background-color: #57B8BF;
}

.info {
  grid-area: i;
  background-color: #3A7B7F;
}

.footer {
  grid-area: f;
  background-color: #1D3D40;
  color: #ffffff;
}

.right {
  grid-area: r;
  background-color: #ffffff;
  color: black;
}
<div class="container">
    <header class="header box">
      <h1>Name</h1>
    </header>
    <nav class="info box">
      <h2>General Information</h2>
    </nav>
    <div class="right box">
      <h3>Right</h3>
    </div>
    <footer class="footer box">
      <h2>Footer</h2>
    </footer>
  </div>

person Nandu Kalidindi    schedule 10.12.2017
comment
Будет много сценариев того, как определяется высота элементов. В большинстве случаев это зависит от родительских элементов. Если вы хотите углубиться, возможно, это поможет вам больше stackoverflow.com/questions/4342092/. Я также постараюсь составить сводное объяснение. - person Nandu Kalidindi; 10.12.2017

У меня была такая же проблема, используйте это:

.container {
  width: 100%;
  height: 100vh;
}
person Community    schedule 10.12.2017
comment
Эй, спасибо! Это сработало. Вы знаете, что это должно быть сделано? - person jdruiz; 10.12.2017
comment
Однако я не уверен на 100%, я думаю, это связано с тем, что размер сетки зависит от контента внутри, поэтому, если контента больше, места больше, если контента меньше, места меньше. Поскольку в ваших классах div/ячейках сетки почти нет контента. Есть белое пространство. Установив высоту 100vh, вы убедитесь, что класс div .container расширяется, чтобы соответствовать телу. Если это помогло, используйте это как принятый ответ. - person ; 10.12.2017