CSS网格在包装后具有自动流动的最小列数

问题描述 投票:0回答:1

是否可以使用具有自动流程的CSS网格,以使包装后的列数最少?怎么样?

我有一个包含6个可自动放置的项目的网格。一旦不是所有6个元素都适合放在一行中,我希望有3列和2行,而不是5列和1行,而第二个元素只有一个元素。

如果可能,我想避免媒体查询。


我想做的事的视觉表示:

全部6个元素合为一行:

| OOO OOO OOO OOO OOO OOO | 
| O1O O2O O3O O4O O5O O6O |
| OOO OOO OOO OOO OOO OOO |

一行中少于6个元素:

| OOO OOO OOO         | 
| O1O O2O O3O         | 
| OOO OOO OOO         | 
|                     | 
| OOO OOO OOO         | 
| O4O O5O O6O         | 
| OOO OOO OOO         | 

少于3个元素排成一行:

| OOO OOO   | 
| O1O O2O   | 
| OOO OOO   | 
|           | 
| OOO OOO   | 
| O3O O4O   | 
| OOO OOO   | 
|           | 
| OOO OOO   | 
| O5O O6O   | 
| OOO OOO   | 

这是我到目前为止所得到的。减小宽度,直到最后一列换行,这时,我希望有3列,每列三项,而不是一列有5列,另一列有1项。

.grid {
  padding: 10px;
  border: 2px solid #444;

  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(50px, 1fr));
  gap: 10px;
  justify-content: space-evenly;
}

.item {
  height: 50px;
  background: #5a5a;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2em;
}
<div class="grid">
  <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>
css flexbox responsive css-grid
1个回答
0
投票

我在下面使用br标记和@media查询进行了演示。

运行代码段,然后按“ Full Page”进行测试:

.grid-box {
  display: inline-block;
  width: 200px;
  height: 150px;
  background-color: blue;
  margin: 2px;
}

.row3 {
  display: none;
}

@media (max-width: 1260px) {
  .row3 {
    display: block;
  }
}

@media (max-width: 636px) {
  .row3 {
    display: none;
  }
}
<div class="grid-box"></div>
<div class="grid-box"></div>
<div class="grid-box"></div>
<br class="row3">
<div class="grid-box"></div>
<div class="grid-box"></div>
<div class="grid-box"></div>
© www.soinside.com 2019 - 2024. All rights reserved.