CSS - grid-column-start 属性



CSS grid-column-start 属性通过指定行、跨度或依赖自动放置来定义网格项目在网格列中的起始位置。它定义网格区域的块起始边缘。

语法

grid-column-start: auto | span n | column-line;

属性值

描述
auto 它自动确定网格项目在网格布局中的位置。默认跨度为 1。
span n 它指定元素占用的列数。
column-line 它指定元素显示必须开始的列。

CSS 网格列起始属性示例

以下示例解释了使用不同值的 grid-column-start 属性。

使用 auto 值的网格列起始属性

为了允许网格项目根据项目内容和网格布局在默认位置开始,我们使用 auto 值。它会根据项目需要的空间及其在网格中的当前位置自动调整起始行。以下示例显示了这一点。

示例

<!DOCTYPE html>
<html>

<head>

   <style>
      .grid-container {
         display: grid;
         grid-template-columns: repeat(4, 1fr);
         gap: 10px;
         padding: 10px;
         background-color: #f0f0f0;
      }

      .grid-item {
         background-color: lightcoral;
         border: 3px solid blue;
         padding: 20px;
         text-align: center;
         color: white;
         grid-column-start: auto;
      }
   </style>
</head>

<body>
   <h2>
      CSS grid-column-start property
   </h2>
   <h4>
      grid-column-start: auto
   </h4>
   <div class="grid-container">
      <div class="grid-item item1 items">
         Item 1
      </div>
      <div class="grid-item">
         Item 2
      </div>
      <div class="grid-item item3 items">
         Item 3
      </div>
      <div class="grid-item">
         Item 4
      </div>
      <div class="grid-item item5 items">
         Item 5
      </div>
   </div>
</body>

</html>

使用 span 值的网格列起始属性

要使网格项目从其起始行开始并跨越 n 列,我们使用 span 指定列数(例如 span 2 - 元素从起始行跨越 2 列)。以下示例显示了这一点。

示例

<!DOCTYPE html>
<html>

<head>

   <style>
      .grid-container {
         display: grid;
         grid-template-columns: repeat(4, 1fr);
         gap: 10px;
         padding: 10px;
         background-color: #f0f0f0;
      }

      .grid-item {
         background-color: lightcoral;
         border: 2px solid #ff6b6b;
         padding: 20px;
         text-align: center;
         color: white;
      }

      .items {
         border: 3px solid blue;
      }

      .item1 {
         grid-column-start: span 2;
      }

      .item3 {
         grid-column-start: span 3;
      }

      .item5 {
         grid-column-start: span 4;
      }
   </style>
</head>

<body>
   <h2>
      CSS grid-column-start property
   </h2>
   <h4>
      grid-column-start: span 2 (item1),
      span 3 (item3), span 4 (item5)
   </h4>
   <p>
      item1- the element takes 
      2 columns space
   </p>
   <p>
      item3- the element takes 
      3 columns space
   </p>
   <p>
      item5- the element takes 
      4 columns space
   </p>
   <div class="grid-container">
      <div class="grid-item item1 items">
         Item 1
      </div>
      <div class="grid-item">
         Item 2
      </div>
      <div class="grid-item item3 items">
         Item 3
      </div>
      <div class="grid-item">
         Item 4
      </div>
      <div class="grid-item item5 items">
         Item 5
      </div>
   </div>
</body>

</html>

使用列号的网格列起始属性

要将网格项目的起始行明确设置为某个列号(即项目应从该列开始),我们指定列号(例如 4 - 元素必须从第 4 列开始显示)。以下示例显示了这一点。

示例

<!DOCTYPE html>
<html>

<head>

   <style>
      .grid-container {
         display: grid;
         grid-template-columns: repeat(4, 1fr);
         gap: 10px;
         padding: 10px;
         background-color: #f0f0f0;
      }

      .grid-item {
         background-color: lightcoral;
         border: 2px solid #ff6b6b;
         padding: 20px;
         text-align: center;
         color: white;
      }

      .items {
         border: 3px solid blue;
      }

      .item1 {
         grid-column-start: 2;
      }

      .item3 {
         grid-column-start: 3;
      }

      .item5 {
         grid-column-start: 4;
      }
   </style>
</head>

<body>
   <h2>
      CSS grid-column-start property
   </h2>
   <h4>
      grid-column-start: 2 (item1),
      3 (item3), 4 (item5)
   </h4>
   <p>
      item1- the element starts 
      showing from column 2
   </p>
   <p>
      item3- the element starts 
      showing from column 3
   </p>
   <p>
      item5- the element starts 
      showing from column 4
   </p>
   <div class="grid-container">
      <div class="grid-item item1 items">
         Item 1
      </div>
      <div class="grid-item">
         Item 2
      </div>
      <div class="grid-item item3 items">
         Item 3
      </div>
      <div class="grid-item">
         Item 4
      </div>
      <div class="grid-item item5 items">
         Item 5
      </div>
   </div>
</body>

</html>

支持的浏览器

属性 Chrome Edge Firefox Safari Opera
grid-column-start 57 16 52 10 44
css_properties_reference.htm
广告