我需要为仪表板设置不同的布局。如果项目超过可见视口,我只需要水平滚动布局容器。我遇到了具有以下要求的布局。
我已经使用 CSS-flexbox 创建了布局样式,但无法获得水平滚动,只能获得垂直滚动。
html,
body {
height: 100%;
margin: 0px;
}
* {
box-sizing: border-box;
}
.flexbox {
height: 100%;
width: 100%;
display: flex;
flex-wrap: wrap;
overflow-x: auto;
background-color: lightgreen;
}
.item {
min-width: 50%;
min-height: 50%;
flex: 1 0 0;
border: 1px solid;
}
.item:nth-child(odd) {
background-color: lightblue;
}
.item:nth-child(even) {
background-color: lightslategray;
}
.item1 {
min-width: 100%;
}
<div class="flexbox">
<div class="item item1">1</div>
<div class="item item2">2</div>
<div class="item item3">3</div>
<div class="item item1">4</div>
<div class="item item2">5</div>
<div class="item item3">6</div>
</div>
https://codepen.io/TechnoGeek/pen/GdZodo
所以,我想,CSS 网格可以帮助解决这个问题。所以我尝试了一些东西,但不明白如何得到它。
html,
body {
height: 100%;
margin: 0px;
}
.grid {
display: grid;
height: 100%;
background-color: lightgreen;
grid-template-columns: repeat(2, 1fr);
grid-template-row: repeat(2, 1fr);
grid-gap: 5px;
/* grid-auto-flow: column; */
}
.item {
border: 1px solid;
}
.item:nth-child(odd) {
background-color: lightblue;
}
.item:nth-child(even) {
background-color: lightslategray;
}
.item1 {
grid-column: 1/3;
}
<div class="grid">
<div class="item item1">1</div>
<div class="item item2">2</div>
<div class="item item3">3</div>
<div class="item item1">4</div>
<div class="item item2">5</div>
<div class="item item3">6</div>
</div>
https://codepen.io/TechnoGeek/pen/BxKoaG
在网格布局中,项目正在缩小以适应布局。
容器内的项目数量是动态的。无论项目计数如何,布局都必须维护每个可见组的结构。
有人可以帮助实现这一目标吗?
提前致谢。
原文由 techno geek 发布,翻译遵循 CC BY-SA 4.0 许可协议
我使用 CSS 网格布局找到了满意的答案。
我在我的问题中使用
fr
定义了网格线,这就是项目缩小的原因。现在我使用了%
因为我希望单元格项目流出可见区域以在需要时产生滚动。和
span
定义网格单元区域的关键字对自动放置网格单元有很大帮助。