CSS grid-column-end 属性通过指定行、跨度或依赖自动放置来确定网格项应结束的列。它定义了网格区域的块端边缘。
属性值
auto: 它自动确定网格项目在网格区域内的位置网格布局。默认范围为 1。
<custom-ident>: 如果有一行标有"<custom-ident>-start"或"<custom-ident>-end",则网格项将为沿着该线定位。
<integer> && <custom-ident>? − 如果给出了名称,则仅考虑具有该名称的行。如果具有该名称的线不足,则所有网格线都会按具有该名称的方式进行处理,以确定正确的位置。 <integer> 值为 0 无效。
span && [ <integer> || <custom-ident> ]: 当名称被指定为自定义标识时,仅考虑具有该名称的行。如果具有该名称的行不足,我们会考虑网格相关侧的所有网格线都具有该名称计数目的。如果未指定 <integer>,则默认值为 1。不允许使用负数或 0。
使用命名网格区域时,会创建隐式线。网格列结束:foo;指定命名区域的结束边缘,除非通过 foo-end 等行明确指定。
适用范围
网格项和绝对-包含块是网格容器的定位框。
DOM 语法
object.style.gridColumnEnd = "auto|<custom-ident>|<integer> && <custom-ident>?|span && [ <integer> || <custom-ident> ]";
CSS grid-column-end: auto
以下示例演示了 grid- column-end:auto 属性自动按照网格项在代码中出现的顺序放置网格项 -
<html>
<head>
<style>
.grid-container {
display: grid;
grid-template-columns: repeat(3, 1fr);
color: white;
text-align: center;
width: 360px;
background-color: lightgreen;
}
.grid-container > div {
background-color: red;
border: 2px solid lightgreen;
padding: 5px;
}
.grid-column-item1 {
grid-column-end: auto;
}
</style>
</head>
<body>
<div class="grid-container">
<div class="grid-column-item1">Grid item 1</div>
<div>Grid item 2</div>
<div>Grid item 3</div>
<div>Grid item 4</div>
<div>Grid item 5</div>
<div>Grid item 6</div>
</div>
</body>
</html>
CSS grid-column-end: <custom-ident>
grid-template-columns:[a] 1fr [b] 1fr [c] 1fr [d] 1fr;属性创建名为 a、b、c 和 d 的四列。
以下示例演示了 grid-column-end:4 属性指定第二个网格项的结束边缘将在第四列 -
<html>
<head>
<style>
.grid-container {
display: grid;
grid-template-columns: [a] 1fr [b] 1fr [c] 1fr [d] 1fr;
grid-template-rows: auto;
background-color: lightgreen;
padding: 5px;
}
.grid-container > div {
background-color: red;
border: 2px solid blue;
padding: 10px;
text-align: center;
}
.grid-item {
grid-column-end: d;
}
</style>
</head>
<body>
<div class="grid-container">
<div>Grid Item 1</div>
<div class="grid-item">Grid Item 2</div>
<div>Grid Item 3</div>
<div>Grid Item 4</div>
<div>Grid Item 5</div>
<div>Grid Item 6</div>
</div>
</body>
</html>
CSS grid-column-end: <integer> && <custom-ident>?
grid-template-columns:[a] 1fr [b] 1fr [a] 1fr [a];属性设置了名为 a、b 的三列。
grid-column-end: 2 a;属性,表示第一个网格项结束于第二个名为"a"的行,即第三条网格线。
下图演示了带有行的列布局:
这是一个示例 -
<html>
<head>
<style>
.grid-container {
display: grid;
grid-template-columns: [a] 1fr [b] 1fr [a] 1fr [a];
grid-template-rows: auto;
background-color: lightgreen;
padding: 5px;
}
.grid-container > div {
background-color: red;
border: 2px solid blue;
padding: 10px;
text-align: center;
}
.grid-item {
grid-column-end: 2 a;
}
</style>
</head>
<body>
<div class="grid-container">
<div class="grid-item">Grid Item 1</div>
<div>Grid Item 2</div>
<div>Grid Item 3</div>
<div>Grid Item 4</div>
</div>
</body>
</html>
CSS grid-column-end: span
以下示例演示了 grid-column-end:span 3 属性指定第二个网格项跨越三列 -
<html>
<head>
<style>
.grid-container {
display: grid;
grid-template-columns: auto auto auto auto;
color: white;
text-align: center;
background-color: lightgreen;
}
.grid-container > div {
background-color: red;
border: 2px solid lightgreen;
padding: 5px;
}
.grid-column-item2 {
grid-column-end: span 3;
}
</style>
</head>
<body>
<div class="grid-container">
<div>Grid item 1</div>
<div class="grid-column-item2">Grid item 2</div>
<div>Grid item 3</div>
<div>Grid item 4</div>
<div>Grid item 5</div>
<div>Grid item 6</div>
</div>
</body>
</html>