【发布时间】:2019-08-06 22:06:05
【问题描述】:
问题:CODEPEN
如何使用 CSS Grid 设计一个网格,以制作一个轮播,其中的网格项响应固定数量的网格列,每个断点会有所不同?
问题: 网格项在响应断点上没有按预期缩放。网格项的峰值不符合规范。
请查看video,了解我希望网格项如何按断点缩放:https://imgur.com/070Zwve
背景
我问了一个关于如何使用 css 网格使网格项水平流动的问题:
Grid CSS container that scrolls horizontally when children use grid-column?
最后我得到了适用于桌面但不适用于任何其他断点的代码:
CSS:
.section {
width: 100%;
display: block;
background: red;
box-sizing: border-box;
padding: 40px 24px;
@media screen and (min-width: 600px) and (max-width: 1139px) {
background: orange;
padding: 56px 48px;
}
@media screen and (min-width: 1140px) {
padding: 64px 48px;
background: green;
}
}
.container {
margin: 0 auto;
background: rgba(244,244,244, .25);
max-width: 599px;
@media screen and (min-width: 600px) and (max-width: 1139px) {
max-width: 1039px;
background: rgba(244,244,244, .25);
}
@media screen and (min-width: 1140px) {
max-width: 1032px;
background: rgba(244,244,244, .25);
}
}
.samba-grid {
display: grid;
background: inherit;
width: 100%;
overflow-x: auto;
overflow-y: hidden;
grid-auto-columns: minmax(55px, 1fr);
grid-gap: 24px;
@media screen and (min-width: 600px) and (max-width: 1139px) {
grid-auto-columns: minmax(44px, 1fr);
grid-gap: 48px;
}
@media screen and (min-width: 1140px) {
grid-auto-columns: minmax(42px, 1fr);
grid-gap: 48px;
}
}
.element {
display: grid;
background: rgba(0,0,0,.3);
grid-column: span 3;
grid-row-start: 2; // REMOVE THIS
@media screen and (min-width: 600px) and (max-width: 1139px) {
grid-column: span 3;
}
@media screen and (min-width: 1140px) {
grid-column: span 4;
}
}
.element img {
width: 100%;
}
HTML:
<section class="section">
<div class="container">
<div class="samba-grid">
<div class="element">
<img src="https://placebear.com/400/500" alt="">
<div class="copy">
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Sint, eveniet commodi?
</div>
</div>
<div class="element">
<img src="https://placebear.com/400/500" alt="">
<div class="copy">
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Sint, eveniet commodi?
</div>
</div>
<div class="element">
<img src="https://placebear.com/400/500" alt="">
<div class="copy">
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Sint, eveniet commodi?
</div>
</div>
<div class="element">
<img src="https://placebear.com/400/500" alt="">
<div class="copy">
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Sint, eveniet commodi?
</div>
</div>
<div class="element">
<img src="https://placebear.com/400/500" alt="">
<div class="copy">
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Sint, eveniet commodi?
</div>
</div>
<div class="element">
<img src="https://placebear.com/400/500" alt="">
<div class="copy">
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Sint, eveniet commodi?
</div>
</div>
<div class="element">
<img src="https://placebear.com/400/500" alt="">
<div class="copy">
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Sint, eveniet commodi?
</div>
</div>
<div class="element">
<img src="https://placebear.com/400/500" alt="">
<div class="copy">
Lorem, ipsum dolor sit amet consectetur adipisicing elit. Sint, eveniet commodi?
</div>
</div>
</div>
</div>
</section>
^ 请注意,此视频显示成行的网格项堆栈不会水平滚动。
【问题讨论】: