如何设置 CSS 网格列的宽度和最大宽度?

How can I set the width and max-width of a CSS Grid Column?

是否可以限制 CSS 网格列的宽度?

body {
  margin: 0;
  padding: 0;
}
.container {
    display: grid;
    grid-template-columns: minmax(17.5%, 250px) minmax(31.25%, 480px) auto;
    grid-template-rows: 100vh;
    grid-gap: 0;
}
.menu {
    padding-top: 32px;
    background: linear-gradient(135deg, #837DB5 0%, #364176 100%);
}
.list-view {
    background-color: #F5F5FC;
}
<div class="container">
  <div class="menu"></div>
  <div class="list-view"></div>
  <div class="details"></div>
</div>

在上面的示例中,菜单始终使用 17.5% 的宽度,因为:

"If max is smaller than min, then max is ignored and the function is treated as min."

来源:https://developer.mozilla.org/en-US/docs/Web/CSS/grid-template-columns

我想要的是一个宽度为 17.5%,最大为 250px 的菜单。这可能吗?

我不确定这种方式是否可行,但另一种方法是使用 flexbox 代替 CSS 网格,您可以轻松实现:

body {
  margin: 0;
  padding: 0;
}

.container {
  display: flex;
  height: 100vh;
}

.menu {
  width: 17.5%;
  max-width: 250px;
  padding-top: 32px;
  background: linear-gradient(135deg, #837DB5 0%, #364176 100%);
}

.list-view {
  width: 32.25%;
  max-width: 480px;
  background-color: #F5F5FC;
}

.details {
  flex: 1;
}
<div class="container">
  <div class="menu"></div>
  <div class="list-view"></div>
  <div class="details"></div>
</div>

执行此操作的一种方法可能是声明:

.container {grid-template-columns: 250px 480px auto;}

作为您的标准规则。

然后,在考虑要应用于第三列的最窄宽度后,您可以应用 @media 查询。

假设您要确保第三列不窄于 100px

250px + 480px + 100px = 830px

因此您需要为 830px 编写一个 @media 查询:

@media only screen and (max-width: 830px) {

    .container {grid-template-columns: 17.5% 31.25% auto;}
}

工作示例:

body {
  margin: 0;
  padding: 0;
}

.container {
    display: grid;
    grid-template-columns: 250px 480px auto;
    grid-template-rows: 100vh;
    grid-gap: 0;
}

.menu {
    padding-top: 32px;
    background: linear-gradient(135deg, #837DB5 0%, #364176 100%);
}

.list-view {
    background-color: #F5F5FC;
}

@media only screen and (max-width: 830px) {
    
    .container {grid-template-columns: 17.5% 31.25% auto;}
}
<div class="container">
  <div class="menu"></div>
  <div class="list-view"></div>
  <div class="details"></div>
</div>

您希望列的标准宽度为 17.5%,最大宽度为 250 像素。

您不能使用 grid-template-columns,因为 minmax() 函数在 max 小于 min 的任何时候计算为 min。这意味着 17.5% 将在更宽的屏幕上覆盖 250px。

一个干净的解决方法是将 grid-template-columns 设置为 ,这会将列收缩到内容的长度。然后在grid item上设置width参数。

.container {
  display: grid;
  grid-template-columns: min-content minmax(31.25%, 480px) auto;
}

.menu {
  width: 17.5%;
  max-width: 250px;
}

但是,网格项目的百分比长度在这种情况下不起作用,因为父引用(列)实质上设置为零宽度 (min-content)。 (fiddle demo).

幸运的是,在这种情况下,因为您的容器设置为视口的宽度,您可以使用 vw 个单位轻松解决这个问题。

.menu {
  width: 17.5vw;
  max-width: 250px;
}

.container {
  display: grid;
  grid-template-columns: min-content minmax(31.25%, 480px) auto;
  grid-template-rows: 100vh;
  grid-gap: 0;
}

.menu {
  width: 17.5vw;
  max-width: 250px;
  padding-top: 32px;
  background: linear-gradient(135deg, #837DB5 0%, #364176 100%);
}

.list-view {
  background-color: #F5F5FC;
}

body {
  margin: 0;
  padding: 0;
}
<div class="container">
  <div class="menu"></div>
  <div class="list-view"></div>
  <div class="details"></div>
</div>

jsFiddle demo