我有一个带有 nowrap 流的 flex 容器,有些元素可能以列开始,我该如何管理它们?这就像树状布局。 最终结果可能是这样的图像:
这是一个 stackblitz和片段:
.container{
display: flex;
width: 100%;
flex-wrap: nowrap;
padding: 5px;
border:2px solid gray;
}
.item{
width: 150px;
flex:1 1 150px;
border: 1px solid green;
margin-right: 2px;
}
<div class="container">
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
<div class="item">4</div>
<div class="item">5</div>
<div class="item">6</div>
<div class="item">7</div>
<div class="item">8</div>
<div class="item">9</div>
</div>
最佳答案
我可以想到 CSS 网格布局来轻松实现此布局:
使用
grid-auto-flow: column
使元素按列方向放置,对特定的
item
元素使用grid-row
和grid-column
来实现所需的配置。
请看下面的演示:
.container{
display: inline-grid; /* inline grid container */
grid-auto-flow: column; /* items placed vertically */
padding: 5px;
border: 2px solid gray;
}
.item:nth-child(2) {
grid-row: 1;
}
.item:nth-child(4),
.item:nth-child(5) {
grid-row: 2;
}
.item:last-child {
grid-row: 4;
}
.item{
width: 150px;
border: 1px solid green;
margin-right: 2px;
}
<div class="container">
<div class="item">1</div>
<div class="item">2</div>
<div class="item">3</div>
<div class="item">4</div>
<div class="item">5</div>
<div class="item">6</div>
<div class="item">7</div>
<div class="item">8</div>
</div>
关于html - flex 包装 : nowrap with row and column,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56075887/