grid-row-start
grid-row-start CSS 属性通过为网格项的网格放置提供一条线、一个跨度或不提供任何东西(自动),来指定网格项在网格行中的起始位置,从而指定其网格区域的内联起始边缘。
试一试
grid-row-start: auto;
grid-row-start: 3;
grid-row-start: -1;
grid-row-start: span 2;
<section class="default-example" id="default-example">
<div class="example-container">
<div class="transition-all" id="example-element">One</div>
<div>Two</div>
<div>Three</div>
</div>
</section>
.example-container {
border: 1px solid #c5c5c5;
display: grid;
grid-template-columns: 1fr 1.5fr 1fr;
grid-template-rows: repeat(3, minmax(40px, auto));
grid-gap: 10px;
width: 200px;
}
.example-container > div {
background-color: rgb(0 0 255 / 0.2);
border: 3px solid blue;
}
#example-element {
background-color: rgb(255 0 200 / 0.2);
border: 3px solid rebeccapurple;
}
语法
css
/* Keyword value */
grid-row-start: auto;
/* <custom-ident> values */
grid-row-start: some-grid-area;
/* <integer> + <custom-ident> values */
grid-row-start: 2;
grid-row-start: some-grid-area 4;
/* span + <integer> + <custom-ident> values */
grid-row-start: span 3;
grid-row-start: span some-grid-area;
grid-row-start: 5 some-grid-area span;
/* Global values */
grid-row-start: inherit;
grid-row-start: initial;
grid-row-start: revert;
grid-row-start: revert-layer;
grid-row-start: unset;
此属性指定为单个 <grid-line> 值。<grid-line> 值可以指定为
- 要么是
auto关键字 - 要么是
<custom-ident>值 - 要么是
<integer>值 - 要么是
<custom-ident>和<integer>,两者用空格分隔 - 要么是关键字
span以及<custom-ident>或<integer>,或两者都有。
值
auto-
是一个关键字,表示该属性对网格项的放置不作任何贡献,表示自动放置、自动跨度或默认跨度为
1。 <custom-ident>-
如果存在名称为“<custom-ident>-start”的命名线,则它将第一条此类线贡献给网格项的放置。
注意: 命名的网格区域会自动生成这种形式的隐式命名线,因此指定
grid-row-start: foo;将选择该命名网格区域的起始边缘(除非在此之前明确指定了另一条名为foo-start的线)。否则,这将被视为指定了整数
1和<custom-ident>。 <integer> && <custom-ident>?-
将第 n 条网格线贡献给网格项的放置。如果给出负整数,它会反向计数,从显式网格的结束边缘开始。
如果名称作为 <custom-ident> 给出,则只计算具有该名称的线。如果具有该名称的线不足,则为了查找此位置,所有隐式网格线都被假定为具有该名称。
<integer>值0是无效的。 span && [ <integer> || <custom-ident> ]-
为网格项的放置贡献一个网格跨度;使得网格项的网格区域的行起始边缘距离结束边缘 n 条线。
如果名称作为 <custom-ident> 给出,则只计算具有该名称的线。如果具有该名称的线不足,则为了计算此跨度,显式网格侧上与搜索方向对应的所有隐式网格线都被假定为具有该名称。
如果省略 <integer>,则默认为
1。负整数或 0 无效。<custom-ident>不能取span和auto值。
正式定义
正式语法
grid-row-start =
<grid-line>
<grid-line> =
auto |
<custom-ident> |
[ [ <integer [-∞,-1]> | <integer [1,∞]> ] && <custom-ident>? ] |
[ span && [ <integer [1,∞]> || <custom-ident> ] ]
示例
设置网格项的行起始位置
HTML
html
<div class="wrapper">
<div class="box1">One</div>
<div class="box2">Two</div>
<div class="box3">Three</div>
<div class="box4">Four</div>
<div class="box5">Five</div>
</div>
CSS
css
.wrapper {
display: grid;
grid-template-columns: repeat(3, 1fr);
grid-auto-rows: 100px;
}
.box1 {
grid-column-start: 1;
grid-column-end: 4;
grid-row-start: 1;
grid-row-end: 3;
}
.box2 {
grid-column-start: 1;
grid-row-start: 3;
grid-row-end: 5;
}
结果
规范
| 规范 |
|---|
| CSS 网格布局模块 Level 2 # line-placement |
浏览器兼容性
加载中…