Как я могу сделать макет flexbox занимать 100% вертикальное пространство?
Как я могу сказать, что строка макета flexbox потребляет оставшееся вертикальное пространство в окне браузера?
У меня есть трехстрочный макет flexbox. Первые две строки - фиксированная высота, но третий - динамический, и я бы хотел, чтобы он вырос до полной высоты браузера.
![enter image description here]()
У меня есть еще один flexbox в строке-3, который создает набор столбцов. Чтобы правильно отрегулировать элементы внутри этих столбцов, мне нужно, чтобы они понимали всю высоту браузера - для таких вещей, как цвет фона и выравнивание элементов в базе. Основной макет в конечном итоге будет похож на это:
![enter image description here]()
.vwrapper {
display: flex;
flex-direction: column;
flex-wrap: nowrap;
justify-content: flex-start;
align-items: stretch;
align-content: stretch;
//height: 1000px;
}
.vwrapper #row1 {
background-color: red;
}
.vwrapper #row2 {
background-color: blue;
}
.vwrapper #row3 {
background-color: green;
flex 1 1 auto;
display: flex;
}
.vwrapper #row3 #col1 {
background-color: yellow;
flex 0 0 240px;
}
.vwrapper #row3 #col2 {
background-color: orange;
flex 1 1;
}
.vwrapper #row3 #col3 {
background-color: purple;
flex 0 0 240px;
}
<body>
<div class="vwrapper">
<div id="row1">
this is the header
</div>
<div id="row2">
this is the second line
</div>
<div id="row3">
<div id="col1">
col1
</div>
<div id="col2">
col2
</div>
<div id="col3">
col3
</div>
</div>
</div>
</body>
Ответы
Ответ 1
Вы должны установить height
в html, body,.wrapper
до 100%
(для того, чтобы наследовать всю высоту), а затем просто установить flex
значения больше чем 1
к .row3
, а не на других.
.wrapper, html, body {
height: 100%;
margin: 0;
}
.wrapper {
display: flex;
flex-direction: column;
}
#row1 {
background-color: red;
}
#row2 {
background-color: blue;
}
#row3 {
background-color: green;
flex:2;
display: flex;
}
#col1 {
background-color: yellow;
flex: 0 0 240px;
}
#col2 {
background-color: orange;
flex: 1 1;
}
#col3 {
background-color: purple;
flex: 0 0 240px;
}
<div class="wrapper">
<div id="row1">this is the header</div>
<div id="row2">this is the second line</div>
<div id="row3">
<div id="col1">col1</div>
<div id="col2">col2</div>
<div id="col3">col3</div>
</div>
</div>
Ответ 2
установите обертку на высоту 100%
.vwrapper {
display: flex;
flex-direction: column;
flex-wrap: nowrap;
justify-content: flex-start;
align-items: stretch;
align-content: stretch;
height: 100%;
}
и установите третью строку для гибкого роста
#row3 {
background-color: green;
flex: 1 1 auto;
display: flex;
}
демо
Ответ 3
Позвольте мне показать вам еще один способ, который работает на 100%. Я также добавлю некоторые отступы для примера.
<div class = "container">
<div class = "flex-pad-x">
<div class = "flex-pad-y">
<div class = "flex-pad-y">
<div class = "flex-grow-y">
Content Centered
</div>
</div>
</div>
</div>
</div>
.container {
position: fixed;
top: 0px;
left: 0px;
bottom: 0px;
right: 0px;
width: 100%;
height: 100%;
}
.flex-pad-x {
padding: 0px 20px;
height: 100%;
display: flex;
}
.flex-pad-y {
padding: 20px 0px;
width: 100%;
display: flex;
flex-direction: column;
}
.flex-grow-y {
flex-grow: 1;
display: flex;
justify-content: center;
align-items: center;
flex-direction: column;
}
Как вы можете видеть, мы можем достичь этого с помощью нескольких оберток для контроля, используя атрибут flex-grow & flex-direction.
1: Когда родительское "flex-direction" является "строкой", его дочерний "flex-grow" работает горизонтально. 2: Когда родительское "flex-direction" - это "столбцы", его дочерний "flex-grow" работает вертикально.
Надеюсь это поможет
Даниил