当下面的代码中的祖先是display: block
时,它按照预期工作。当它是display: flex
嵌套网格缩小。为什么我的CSS网格在其祖先显示时收缩:flex?
我想了解为什么会发生这种情况。
只需在下面的代码中取消注释display: block
即可查看结果。电网停下来跨越允许的整个区域。
.ctnr{
display: flex;
//display: block;
flex-flow: column;
align-items: stretch;
}
header{ background: red; height: 2rem; }
main{
\t max-width: 15rem;
\t height: 25rem;
\t margin: auto;
\t overflow: auto;
}
.grid{
display: grid;
\t height: 25rem;
align-items: stretch;
grid-template-areas:
"c1 c1 c1 c2 c3 c3 c3"
"c4 c4 c4 c4 c3 c3 c3"
"c4 c4 c4 c4 c5 c6 c6"
"c4 c4 c4 c4 c7 c7 c7";
\t grid-gap: 10px;
}
.grid article{
\t cursor: pointer;
}
.grid article:nth-child(odd){
background: yellow;
}
.grid article:nth-child(even){
background: cyan;
}
.c1{ grid-area: c1; }
.c2{ grid-area: c2; }
.c3{ grid-area: c3; }
.c4{ grid-area: c4; }
.c5{ grid-area: c5; }
.c6{ grid-area: c6; }
.c7{ grid-area: c7; }
<div class="ctnr">
<header></header>
<main>
<div class="grid">
<article class="c1">1</article>
<article class="c2">2</article>
<article class="c3">3</article>
<article class="c4">4</article>
<article class="c5">5</article>
<article class="c6">6</article>
<article class="c7">7</article>
</div>
</main>
<footer></footer>
</div>
这是通过给予宽度主
main{
width: 90%;
max-width: 15rem;
// ...
}
这种“决心”的问题解决了,但是我真的不明白这里发生了什么。例如,header
即使没有宽度也不缩小。
https://jsfiddle.net/6k2313ub/1/
摘要:'保证金:auto'不起作用同一个Flexbox的内部。最后一个环节需要处理很多。太好了! – Ced
只是FYI,如果你使用'align-self:center'而不是'margin:auto',你会得到同样的效果。两种方法都消耗线上的空闲空间。这就是flex的工作原理。块布局在这方面是不同的。 –