2 回答
TA贡献1777条经验 获得超10个赞
您直接设置网格项的高度,而不是在网格容器上定义任何行。因此,网格算法必须创建行来容纳网格区域。它只需要创建两行即可完成布局。这就是为什么框 2 和 3 下方有一个很大的间隙。框 1 最高,它设置顶行的高度。
您想要的布局至少需要三行。
尝试这种方法:在容器级别设置行(和高度),然后设置网格区域。
.container {
display: grid;
grid-template-columns: 1fr 2fr 2fr;
grid-template-rows: repeat(3, 150px);
grid-gap: 10px;
}
.box-1 {
grid-column: 1;
grid-row: 1 / span 2;
background-color: lightgreen;
}
.box-2 {
grid-column: 2;
grid-row: 1;
background-color: lightsalmon;
}
.box-3 {
grid-column: 3;
grid-row: 1;
background-color: lightsalmon;
}
.box-4 {
grid-column: 2 / -1;
grid-row: 2 / 4;
background-color: lightskyblue;
}
.box-5 {
grid-column: 1;
grid-row: 3;
background-color: lightseagreen;
}
<div class="container">
<div class="box-1">1</div>
<div class="box-2">2</div>
<div class="box-3">3</div>
<div class="box-4">4</div>
<div class="box-5">5</div>
</div>
如果您需要更多选项来调整网格区域的大小,请增加行/列数。
例如,代替这个:
grid-template-rows: repeat(3, 150px)
...你可以这样做:
grid-template-rows: repeat(9, 50px)
...然后根据需要跨行跨越网格区域。
TA贡献1847条经验 获得超7个赞
将盒子 1 和盒子 3 放在一个 div 中,将其垂直对齐,并将所有其他 3 个盒子放在一个容器中,放在 1 个容器中,这样你就可以轻松做到这一点
- 2 回答
- 0 关注
- 120 浏览
添加回答
举报