具有 minmax 的网格模板列在应该收缩时却没有收缩

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

我有一个基本布局 - 一个装有几张卡片的容器。每张卡片的宽度必须在 300 像素到 500 像素之间。

我建议一个简单的

grid-template-columns: repeat(auto-fit, minmax(300px, 500px))
应该可以工作,但事实并非如此。对于 700 像素的容器,它应该在一行中容纳两张 350 像素的卡片,但它没有这样做:

.container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 500px));
  gap: 20px;
  width: 700px;
  border: 1px solid #000;
}

.card {
  padding: 30px;
  background-color: #ddd;
}
<div class="container">
  <div class="card"></div>
  <div class="card"></div>
</div>  

我尝试使用

grid-template-columns: repeat(auto-fit, minmax(300px, 1fr))
并将
max-width: 500px
添加到卡片上,除了卡片之间的间隙之外,这几乎是我所需要的。 如果有两张卡片,并且容器宽度为 2000px,我需要将两张 500px 的卡片绘制在左侧,并留有 20px 的间隙。相反,我有巨大的差距。

.container {
  width: 2000px;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 20px;
}

.card {
  max-width: 500px;
  padding: 20px;
  background-color: #ddd;
}
<div class="container">
  <div class="card"></div>
  <div class="card"></div>
</div>  

是否可以强制间隙为20px?而且我不允许使用媒体查询,因为整个东西可能会在有/没有子菜单等的不同地方使用。

css css-grid
1个回答
0
投票

auto-fit
似乎不是您所需要的。
auto-fill
似乎符合您的要求。

.container {
  width: 2000px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 20px;
}

.card {
  max-width: 500px;
  padding: 20px;
  background-color: #ddd;
}
<div class="container">
  <div class="card"></div>
  <div class="card"></div>
</div>

© www.soinside.com 2019 - 2024. All rights reserved.