是否有grid属性的类似于flex-grow
的模拟方法?
我希望我的网格区域能够适应它们接收到的内容,但一些区域可以像flex-grow
和flex
一样占用更多的空间。
实际上,在下面的示例中:
turquoise
应该是不可见的,因为它适应其内容。footer
也应该是不可见的,因为它没有内容。- 中间部分应该像
flex-grow
一样占据页面的剩余部分。
更具体地说,我想要这段代码:
.ctnr {
display: grid;
min-height: 100vh;
grid-template-areas:
"header header"
"nav main"
"footer footer";
}
.test {
background: black;
height: 1rem;
}
header {
grid-area: header;
background: turquoise;
}
nav {
grid-area: nav;
background: grey;
}
main {
grid-area: main;
}
footer {
grid-area: footer;
background: yellow
}
<div class="ctnr">
<header>
<div class="test"></div>
</header>
<nav></nav>
<main></main>
<footer></footer>
</div>
表现为这段代码:
.ctnr {
display: flex;
flex-direction: column;
height: 100vh;
}
.panel {
flex-grow: 1;
display: flex;
}
header {
flex-grow: 0;
background: turquoise;
}
nav {
min-width: 10rem;
background: grey
}
footer {
background: yellow
}
<div class="ctnr">
<header>hey</header>
<div class="panel">
<nav></nav>
<main></main>
</div>
<footer></footer>
</div>
不需要 div.panel
,也不需要添加任何其他标记。
我之所以想这样做,是因为多一个 div
元素让我感到很烦。