本文介绍了随着项目数的增加,更改网格中的列数和行数的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我必须设计一个响应式网格。
网格应根据项目数(而不是屏幕的大小)而变化。
I have to design a responsive grid.
The grid should change based on the number of items (instead of the size of the screen).
从5到6个项目应为2x3,
从7到9个项目应为3x3,
从10到12个项目应为3x4,
从13到16的项目应该是4x4,
等...
From 5 to 6 items should be 2x3,
from 7 to 9 items should be 3x3,
from 10 to 12 items should be 3x4,
from 13 to 16 items should be 4x4,and so on...
这是我可以使用CSS Grid做到的吗?
Is this something I can do using CSS Grid?
这是我尝试过的:
<main>
<figure>
<img src="https://placekitten.com/600/400" alt="">
</figure>
<figure>
<img src="https://placekitten.com/600/400" alt="">
</figure>
<figure>
<img src="https://placekitten.com/600/400" alt="">
</figure>
<figure>
<img src="https://placekitten.com/600/400" alt="">
</figure>
<figure>
<img src="https://placekitten.com/600/400" alt="">
</figure>
</main>
main {
/* display: flex; */
/* flex-wrap: wrap; */
display: grid;
grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr));
align-content: stretch;
height: 100vh;
}
figure {
margin: 0;
/* flex-grow: 1; */
/* flex-basis: 12rem; */
}
img {
width: 100%;
height: 100%;
object-fit: cover;
}
推荐答案
隐式列创建可以做到这一点。您可以考虑 nth-child()
/ nth-last-child()
在到达时创建新列特定列数:
Implicit columns creation can do this. You can consider nth-child()
/nth-last-child()
to create a new column when you reach a specific number of columns:
.container {
display:inline-grid;
grid-auto-columns:1fr;
width:100px;
vertical-align:top;
}
.container > :nth-child(2) {
grid-column:2;
}
.container > :nth-last-child(5) ~ :nth-child(3),
.container > :nth-last-child(7) ~ :nth-child(3), /* 7 = 5 + 2 */
.container > :nth-last-child(9) ~ :nth-child(3){ /* 9 = 7 + 2 */
grid-column:3;
}
.container > :nth-last-child(10) ~ :nth-child(4),
.container > :nth-last-child(13) ~ :nth-child(4), /* 13 = 10 + 3 */
.container > :nth-last-child(16) ~ :nth-child(4){ /* 16 = 13 + 3 */
grid-column:4;
}
.container > :nth-last-child(17) ~ :nth-child(5),
.container > :nth-last-child(21) ~ :nth-child(5), /* 21 = 17 + 4 */
.container > :nth-last-child(25) ~ :nth-child(5){ /* 25 = 21 + 4 */
grid-column:5;
}
.container > * {
border:1px solid red;
}
.container > *::before {
content:"";
display:inline-block;
padding-top:100%;
}
<div class="container">
<div></div>
</div>
<div class="container">
<div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
<div class="container">
<div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div><div></div>
</div>
这篇关于随着项目数的增加,更改网格中的列数和行数的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!