我将通过 css-grid 创建一个具有动态图像数量的布局,但我有一个问题,我希望前 10 个图像能够被创造性地设计,而后面的图像我希望它们被订购在网格中。
从 11 开始,他们会在网格中找到空间的地方插入。 我附上了参考图像和 this jsfiddle 链接以及我的代码示例。
请帮助我, 预先感谢
错误可能就在这里
#container .mix:nth-child(n+11){
grid-column-start: 1;
grid-row-start: 43;
grid-column: span 4;
grid-row: span 2;
}
#container {
display: grid;
grid-template-columns:repeat(15, 1fr);
grid-template-rows: repeat(20, 1fr);
}
#container .mix:nth-child(1){
grid-column: 7 / span 9;
grid-row: 1 / span 8;
}
#container .mix:nth-child(2){
grid-column: 1 / span 9;
grid-row: 4 / span 8;
}
#container .mix:nth-child(3){
grid-column: 9 / span 7;
grid-row: 8 / span 4;
}
#container .mix:nth-child(4){
grid-column: 1 / span 9;
grid-row: 11 / span 8;
}
#container .mix:nth-child(5){
grid-column: 7 / span 9;
grid-row: 17 / span 8;
}
#container .mix:nth-child(6){
grid-column: 1 / span 5;
grid-row: 22 / span 8;
}
#container .mix:nth-child(7){
grid-column: 5 / span 7;
grid-row: 25 / span 8;
}
#container .mix:nth-child(8){
grid-column: 10 / span 6;
grid-row: 23 / span 8;
}
#container .mix:nth-child(9){
grid-column: 1 / span 8;
grid-row: 31 / span 8;
}
#container .mix:nth-child(10){
grid-column: 8 / span 8;
grid-row: 34 / span 8;
}
#container .mix:nth-child(n+11){
grid-column-start: 1;
grid-row-start: 43;
grid-column: span 4;
grid-row: span 2;
}
<div id="container">
<div class="mix">
<img src="https://via.placeholder.com/480x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/480x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<!-- end top 10 images -->
<div class="mix">
<img src="https://via.placeholder.com/400x240/ff0000">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240/ff0000">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240/ff0000">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240/ff0000">
</div>
</div><!-- end container -->
问题是前 10 个孩子之间的差距足够大,足以让后面的孩子填补。所以只要你想保留这么大的空间,你就无法用单个容器实现你想要的(只要图像的数量是动态的。
由于第一部分的子项数量是静态的。最好将其分成 2 个容器:一个用于第一个图像,一个用于其余图像。 检查下面的代码。尽管上面的宽度几乎是动态的,而图像具有静态尺寸。因此,除非您将图像大小设置为动态或将容器宽度设置为静态。你不可能在第二个容器中获得每行 3 件物品
.creative {
display: grid;
grid-template-columns:repeat(15, 1fr);
grid-template-rows: repeat(20, 1fr);
}
.ordered {
display: flex;
flex-wrap: wrap;
}
.creative .mix:nth-child(1){
grid-column: 1 / span 9;
grid-row: 1 / span 8;
}
.creative .mix:nth-child(2){
grid-column: 1 / span 9;
grid-row: 4 / span 8;
}
.creative .mix:nth-child(3){
grid-column: 9 / span 7;
grid-row: 8 / span 4;
}
#container .mix:nth-child(4){
grid-column: 1 / span 9;
grid-row: 11 / span 8;
}
.creative .mix:nth-child(5){
grid-column: 7 / span 9;
grid-row: 17 / span 8;
}
.creative .mix:nth-child(6){
grid-column: 1 / span 5;
grid-row: 22 / span 8;
}
.creative .mix:nth-child(7){
grid-column: 5 / span 7;
grid-row: 25 / span 8;
}
.creative .mix:nth-child(8){
grid-column: 10 / span 6;
grid-row: 23 / span 8;
}
.creative .mix:nth-child(9){
grid-column: 1 / span 8;
grid-row: 31 / span 8;
}
.creative .mix:nth-child(10){
grid-column: 8 / span 8;
grid-row: 34 / span 8;
}
<div class="container creative">
<div class="mix">
<img src="https://via.placeholder.com/480x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/480x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240">
</div>
</div>
<!-- end top 10 images -->
<div class="container ordered">
<div class="mix">
<img src="https://via.placeholder.com/400x240/ff0000">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240/ff0000">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240/ff0000">
</div>
<div class="mix">
<img src="https://via.placeholder.com/400x240/ff0000">
</div>
</div><!-- end container -->
我同意 Michaël Vanderheyden 的观点,我对网格做了几次测试,我认为以同样的方式划分成一个新的网格,在其中将新元素按顺序放置在图像中是更可行的,因为我知道目标是使用 display: grid,但是如果您使用 CSS 框架,您可以使用新的可能性和更好的设施,我知道有人已经建议了它,但是您可以标准化网格的行为,甚至访问内部元素的更多行为选项,使用framworks(HTML-css-JS),我不知道需求的情况,但我认为建议是有效的,祝你好运