CSS 网格不考虑最小最大值中的最小值以及自动调整



嗨,我试图创建具有该行为的响应列。 列的宽度可以在 335px 或 540px 之间。

但是当我使用grid-template-columns: repeat(auto-fit, minmax(335px, 540px))时,似乎只考虑了 540px。

就像如果有 700px 可用一样,我希望 3 个项目排列在 2 列中。

.box {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(335px, 540px));
grid-gap: 10px;
row-gap: 10px;
}
.item {
background: red;
}
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width">
<title>JS Bin</title>
</head>
<body>
<div class="box">
<div class="item item1">1</div>
<div class="item item2">2</div>
<div class="item item3">3</div>
</div>
</body>
</html>

考虑max-width你的元素,并在minmax()中使用1fr

.box {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(335px, 1fr));
grid-gap: 10px;
}
.item {
background: red;
max-width: 540px;
}
<div class="box">
<div class="item item1">1</div>
<div class="item item2">2</div>
<div class="item item3">3</div>
</div>

最新更新