CSS Grid 中的列居中

eiv*_*dml 5 html css grid-layout css-grid

我正在尝试使用本机 CSS 网格属性创建一个简单的 css 网格。它按我的意愿工作,但我想创建一个可以在网格中居中列的实用程序类。

有没有办法创建__centered实用程序类,以便我可以将其应用于中心列?我知道我可以在列之前添加空列 div,但我想要一个更干净的解决方案。

.l-wrap {
  width: 100%;
  max-width: 1196px;
  margin: 0 auto;
}

.l-grid {
  display: grid;
  grid-gap: 52px;
  grid-template-columns: repeat(6, 1fr);
  background-color: orangered;
}
.l-grid--col {
  grid-column: auto/span 6;
}
.l-grid--col-1 {
  grid-column: auto/span 1;
  background-color: lightblue;
}
.l-grid--col-2 {
  grid-column: auto/span 2;
  background-color: lightblue;
}
.l-grid--col-3 {
  grid-column: auto/span 3;
  background-color: lightblue;
}
.l-grid--col-4 {
  grid-column: auto/span 4;
  background-color: lightblue;
}
.l-grid--col-5 {
  grid-column: auto/span 5;
  background-color: lightblue;
}
.l-grid--col-6 {
  grid-column: auto/span 6;
  background-color: lightblue;
}
Run Code Online (Sandbox Code Playgroud)
<div class="l-wrap">
  <div class="l-grid l-grid__centered">
    <div class="l-grid--col-2">
      <p>This should span 2 and be centered.</p>
    </div>
  </div>
</div>
Run Code Online (Sandbox Code Playgroud)

Mic*_*l_B 5

CSS Grid 提供了justify-itemsjustify-self属性,可用于沿行轴对齐网格项。

justify-items适用于网格容器。justify-self适用于网格项。

因此,您的实用程序类可能如下所示:

.l-grid__centered {
    justify-self: center;
    grid-column: 1 / -1;
}
Run Code Online (Sandbox Code Playgroud)

这告诉网格项将自己居中在从第一列到最后一列的网格区域中的行上。(负整数值grid-columngrid-row从末端开始计数。

.l-grid__centered {
    justify-self: center;
    grid-column: 1 / -1;
}
Run Code Online (Sandbox Code Playgroud)
.l-wrap {
  width: 100%;
  max-width: 1196px;
  margin: 0 auto;
}

.l-grid {
  display: grid;
  grid-gap: 52px;
  grid-template-columns: repeat(6, 1fr);
  background-color: orangered;
}
.l-grid--col {
  grid-column: auto/span 6;
}
.l-grid--col-1 {
  grid-column: auto/span 1;
  background-color: lightblue;
}
.l-grid--col-2 {
  grid-column: auto/span 2;
  background-color: lightblue;
}
.l-grid--col-3 {
  grid-column: auto/span 3;
  background-color: lightblue;
}
.l-grid--col-4 {
  grid-column: auto/span 4;
  background-color: lightblue;
}
.l-grid--col-5 {
  grid-column: auto/span 5;
  background-color: lightblue;
}
.l-grid--col-6 {
  grid-column: auto/span 6;
  background-color: lightblue;
}

    .l-grid__centered {
        justify-self: center;
        grid-column: 1 / -1;
    }
Run Code Online (Sandbox Code Playgroud)

jsFiddle 演示

注意:实用程序类应用于网格项,而不是网格容器。此外,此方法打破了原始内容的 2 列网格区域。居中的内容将能够扩展到整行。


或者,当使用六列网格时,要将两列网格区域水平居中,您的实用程序类可以如下所示:

.__centered {
  grid-column: 3 / span 2;
 }
Run Code Online (Sandbox Code Playgroud)

或者

.__centered {
  grid-column: 3 / -3; 
 }
Run Code Online (Sandbox Code Playgroud)

<div class="l-wrap">
  <div class="l-grid l-grid__centered">
    <div class="l-grid--col-2">
      <p>This should span 2 and be centered.</p>
    </div>
  </div>
</div>
Run Code Online (Sandbox Code Playgroud)
.__centered {
  grid-column: 3 / span 2;
 }
Run Code Online (Sandbox Code Playgroud)

jsFiddle 演示

注意:此解决方案仅将偶数网格区域居中。