ArkUI栅格布局(GridRow和GridCol)详解(附带实例)
栅格布局是一种通用的辅助定位工具,对移动设备的界面设计有较好的借鉴作用。其主要优势包括:
GridRow 为栅格容器组件,需要与栅格子组件 GridCol 在栅格布局场景中联合使用。
栅格系统默认断点将设备宽度分为 xs、sm、md、lg 四类,如下表所示。
在 GridRow 栅格组件中,允许开发者使用 breakpoints 自定义断点的取值范围,最多支持 6 个断点,除了默认的 4 个断点外,还可以启用 xl、xxl 两个断点,总共支持 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备的布局设置,如下表所示。
针对断点位置,开发者可以根据实际使用场景,通过一个单调递增数组来进行设置。由于 breakpoints 最多支持 6 个断点,因此单调递增数组的最大长度为 5。例如:
又如:
栅格系统通过监听窗口或容器的尺寸变化进行断点,通过 reference 设置断点切换参考物。考虑到应用可能以非全屏窗口的形式显示,因此以应用窗口宽度为参照物更为通用。
例如,使用栅格的默认列数(12 列),通过断点设置将应用宽度分成 6 个区间,在各区间中,每个栅格子元素占用的列数均不同,示例代码如下:

图 1 栅格容器布局显示效果
Columns 的默认值为 12,即在未设置 columns 时,任何断点下,栅格布局被分成 12 列,示例代码如下:

图 2 设置布局总列数后的显示效果
当 columns 为自定义值时,栅格布局在任何尺寸设备下都被分为 columns 列。在下面的实例中,分别设置栅格布局列数为 4 和 8,子元素默认占一列。

图 3 不同列数的显示效果对比
当 columns 类型为 GridRowColumnOption 时,支持 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备的总列数设置,各个尺寸下的数值可不同,示例代码如下:

图 4 相同列数在不同尺寸下的显示效果
若只设置 sm 和 md 的栅格总列数,则较小的尺寸使用默认 columns 值(即 12),较大的尺寸使用前一个尺寸的 columns 值。这里只设置 sm:4 和 md:8,则较小尺寸的是 xs:12,较大尺寸的参照 md 的设置,为 lg:8, xl:8, xxl:8。
子组件默认从左往右排列,示例代码如下:

图 5 默认子组件排列方向显示效果
子组件从右往左排列的示例代码如下:

图 6 子组件从右向左排列的显示效果
例如,在下面的实例中,设置子组件在水平与垂直方向上与相邻元素的间距为 10:

图 7 同时设置子组件间水平和垂直方向间距的显示效果
当 gutter 的类型为 GutterOption 时,可以单独设置栅格子组件的水平和垂直间距。此时,x 属性用于设置水平方向的间距,y 属性用于设置垂直方向的间距。示例代码如下:

图 8 单独设置子组件间水平和垂直方向间距的显示效果
设置 span 的示例代码如下:

图 9 设置Span之后的显示效果
设置 offset 的示例代码如下:

图 10 设置offset之后的显示效果
设置 order 的示例代码如下:

图 11 设置order之后的显示效果
示例代码如下:

图 12 设置span之后的显示效果
当 span 类型为 GridColColumnOption 时,支持在 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备中设置子组件所占列数,并且各个尺寸下列数值可不同。示例代码如下:

图 13 不同尺寸下的显示效果
示例代码如下:

图 14 设置offset之后的显示效果
栅格默认分成 12 列,每一个子组件默认占 1 列,当偏移 2 列时,每个子组件及间距共占 3 列,因此一行放 4 个子组件。
当 offset 的类型为 GridColColumnOption 时,支持在 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备中设置子组件所占列数,并且各个尺寸下列数值可不同,示例代码如下:

图 15 子组件在不同断点处的偏移量
order 设置的示例代码如下:

图 16 设置order之后的显示效果
当 order 类型为 GridColColumnOption 时,支持 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备中设置子组件排序次序。
例如,在 xs 设备中,子组件排列顺序为 1234;在 sm 设备中为 2341;在 md 子组件中排列顺序为 3412;在 lg 子组件中排列顺序为 2431,示例代码如下:

图 17 不同尺寸设备下不同order的显示效果
在下面实例中,栅格把整个空间分为 12 份;

图 18 栅格组件的嵌套使用
综上所述,栅格组件提供了丰富的自定义能力,功能异常灵活和强大。只需明确栅格在不同断点下的 columns、margin、gutter 及 span 等参数,即可确定最终布局,而无须关心具体的设备类型及设备状态(如横竖屏)等。
- 提供可循的规律:栅格布局可以提供规律性的结构,解决了多尺寸多设备的动态布局问题。通过将页面划分为等宽的列和行,可以方便地对页面元素进行定位和排版;
- 统一的定位标注:栅格布局可以为系统提供统一的定位标注,保证不同设备上各个模块的布局一致性,从而减少设计和开发的复杂度,提高工作效率;
- 灵活的间距调整方法:栅格布局可以提供一种灵活的间距调整方法,满足特殊场景布局调整的需求。通过调整列与列和行与行的间距,可以控制整个页面的排版效果;
- 自动换行和自适应:栅格布局可以完成一对多布局的自动换行和自适应。当页面元素的数量超出了一行或一列的容量时,它们会自动换到下一行或下一列,并且在不同的设备上自适应排版,使得页面布局更加灵活,有更强的适应性。
GridRow 为栅格容器组件,需要与栅格子组件 GridCol 在栅格布局场景中联合使用。
栅格容器GridRow
栅格系统以设备的水平宽度(屏幕密度像素值,单位为 vp)作为断点依据,定义设备的宽度类型,形成了一套断点规则。开发者可根据需求在不同的断点区间实现不同的页面布局效果。栅格系统默认断点将设备宽度分为 xs、sm、md、lg 四类,如下表所示。
断点名称 | 取值范围(vp) | 设备描述 |
---|---|---|
xs | [0, 320] | 最小宽度类型设备 |
sm | [320, 520] | 小宽度类型设备 |
md | [520, 840] | 中等宽度类型设备 |
lg | [840, +∞) | 大宽度类型设备 |
在 GridRow 栅格组件中,允许开发者使用 breakpoints 自定义断点的取值范围,最多支持 6 个断点,除了默认的 4 个断点外,还可以启用 xl、xxl 两个断点,总共支持 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备的布局设置,如下表所示。
断点名称 | 设备描述 |
---|---|
xs | 最小宽度类型设备 |
sm | 小宽度类型设备 |
md | 中等宽度类型设备 |
lg | 大宽度类型设备 |
xl | 特大宽度类型设备 |
xxl | 超大宽度类型设备 |
针对断点位置,开发者可以根据实际使用场景,通过一个单调递增数组来进行设置。由于 breakpoints 最多支持 6 个断点,因此单调递增数组的最大长度为 5。例如:
breakpoints: {value: ['100vp', '200vp']}表示启用 xs、sm、md 共 3 个断点,小于 100vp 的为 xs,100~200vp 的为 sm,大于 200vp 的为 md。
又如:
breakpoints: {value: ['320vp', '520vp', '840vp', '1080vp']}表示启用 xs、sm、md、lg、xl 共 5 个断点,小于 320vp 的为 xs,320~520vp 的为 sm,520~840vp 的为 md,840~1080vp 的为 lg,大于 1080vp 的为 xl。
栅格系统通过监听窗口或容器的尺寸变化进行断点,通过 reference 设置断点切换参考物。考虑到应用可能以非全屏窗口的形式显示,因此以应用窗口宽度为参照物更为通用。
例如,使用栅格的默认列数(12 列),通过断点设置将应用宽度分成 6 个区间,在各区间中,每个栅格子元素占用的列数均不同,示例代码如下:
@Entry @Component struct GridLayoutDemo { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown ]; build() { GridRow({ breakpoints: { value: ['200vp', '300vp', '400vp', '500vp', '600vp'], reference: BreakpointsReference.WindowSize } }) { ForEach(this.bgColors, (color: Color, index?: number) => { GridCol({ span: { xs: 2, // 在最小宽度类型设备上,栅格子组件占据栅格容器 2 列 sm: 3, // 在小宽度类型设备上,栅格子组件占据栅格容器 3 列 md: 4, // 在中等宽度类型设备上,栅格子组件占据栅格容器 4 列 lg: 6, // 在大宽度类型设备上,栅格子组件占据栅格容器 6 列 xl: 8, // 在特大宽度类型设备上,栅格子组件占据栅格容器 8 列 xxl: 12 // 在超大宽度类型设备上,栅格子组件占据栅格容器 12 列 } }) { Row() { Text(`${index}`) } .width('100%') .height('50vp') } .backgroundColor(color) }) } } }显示效果如下图所示:

图 1 栅格容器布局显示效果
布局的总列数
在 GridRow 中,通过 columns 设置栅格布局的总列数。Columns 的默认值为 12,即在未设置 columns 时,任何断点下,栅格布局被分成 12 列,示例代码如下:
@Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown, Color.Red, Color.Orange, Color.Yellow, Color.Green ]; build() { // 栅格行组件 GridRow() { // 通过循环渲染,向栅格行组件中添加栅格列子组件 ForEach(this.bgColors, (item: Color, index?: number) => { GridCol() { Row() { Text(`${index}`) } .width('100%') .height('50') .backgroundColor(item) } }) } .width('100%') .height('100%') } }显示效果如下图所示:

图 2 设置布局总列数后的显示效果
当 columns 为自定义值时,栅格布局在任何尺寸设备下都被分为 columns 列。在下面的实例中,分别设置栅格布局列数为 4 和 8,子元素默认占一列。
import { promptAction } from '@kit.ArkUI'; import { BusinessError } from '@kit.BasicServicesKit'; // 使用 Record 类型数据设置边框样式 let BorderWH: Record<string, Color | number> = { 'color': Color.Blue, 'width': 2 }; @Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown ]; build() { Column() { Row() { // 栅格行组件,设置一行显示 4 列 GridRow({ columns: 4 }) { ForEach(this.bgColors, (item: Color, index?: number | underfined) => { GridCol() { Row() { Text(`${index}`) } .width('100%') .height('50') } .backgroundColor(item) }) } .width('100%') .height('100%') } .height(160) .border(BorderWH) .width('90%') Row() { // 栅格行组件,设置一行显示 8 列 GridRow({ columns: 8 }) { ForEach(this.bgColors, (item: Color, index?: number | undefined) => { GridCol() { Row() { Text(`${index}`) } .width('100%') .height('50') } .backgroundColor(item) }) } .width('100%') .height('100%') } .height(160) .border(BorderWH) .width('90%') } } }显示效果如下图所示:

图 3 不同列数的显示效果对比
当 columns 类型为 GridRowColumnOption 时,支持 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备的总列数设置,各个尺寸下的数值可不同,示例代码如下:
import { promptAction } from '@kit.ArkUI'; import { BusinessError } from '@kit.BasicServicesKit'; @Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown ]; @State currentBreakpoint: string = 'unknown'; build() { GridRow({ // 如果断点是 sm,每行显示 4 列;如果断点是 md,每行显示 8 列 columns: { sm: 4, md: 8 }, // 断点定义,5 个数字定义 6 个断点:xs, sm, md, lg, xl, xxl breakpoints: { value: ['200vp', '300vp', '400vp', '500vp', '600vp'] } }) { ForEach(this.bgColors, (item: Color, index?: number) => { GridCol() { Row() { Text(`${index}`) } .width('100%') .height('50') .backgroundColor(item) } }) GridCol() { Row() { Text(this.currentBreakpoint) .fontColor(Color.White) .fontWeight(FontWeight.Bold) .backgroundColor(Color.Black) .width('100%') .height('100%') .textAlign(TextAlign.Center) } .width('100%') .height('50') } .onBreakpointChange((breakpoint: string) => { this.currentBreakpoint = breakpoint; }) } } }显示效果如下图所示:

图 4 相同列数在不同尺寸下的显示效果
若只设置 sm 和 md 的栅格总列数,则较小的尺寸使用默认 columns 值(即 12),较大的尺寸使用前一个尺寸的 columns 值。这里只设置 sm:4 和 md:8,则较小尺寸的是 xs:12,较大尺寸的参照 md 的设置,为 lg:8, xl:8, xxl:8。
GridRow排列方向
栅格布局中,可以通过设置 GridRow 的 direction 属性来指定栅格子组件在栅格容器中的排列方向。该属性可以设置为 GridRowDirection.Row(从左往右排列)或 GridRowDirection.RowReverse(从右往左排列),以满足不同的布局需求。通过合理的 direction 属性设置,可以使得页面布局更加灵活和符合设计要求。子组件默认从左往右排列,示例代码如下:
@Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown, Color.Red, Color.Orange, Color.Yellow, Color.Green ]; build() { // 子组件从左往右排列(默认值) GridRow({ direction: GridRowDirection.Row, columns: 8 }) { ForEach(this.bgColors, (item: Color, index?: number) => { GridCol() { Row() { Text(`${index}`) } .width('100%') .height('50') } .backgroundColor(item) }) } .width('100%') .height('100%') } }显示效果如下图所示:

图 5 默认子组件排列方向显示效果
子组件从右往左排列的示例代码如下:
@Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown, Color.Red, Color.Orange, Color.Yellow, Color.Green ]; build() { // 子组件从右往左排列 GridRow({ direction: GridRowDirection.RowReverse, columns: 8 }) { ForEach(this.bgColors, (item: Color, index?: number) => { GridCol() { Row() { Text(`${index}`) } .width('100%') .height('50') } .backgroundColor(item) }) } .width('100%') .height('100%') } }显示效果如下图所示:

图 6 子组件从右向左排列的显示效果
GridRow子组件间距
在 GridRow 中,可以通过 gutter 属性来设置子元素在水平和垂直方向的间距。当 gutter 的类型为 number 时,栅格子组件的水平和垂直方向的间距将被统一设置,且两者的间距值相等。例如,在下面的实例中,设置子组件在水平与垂直方向上与相邻元素的间距为 10:
@Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown, Color.Red, Color.Orange, Color.Yellow, Color.Green ]; build() { // gutter 设置子组件在水平与垂直方向上与相邻元素的间距为 10 vp GridRow({ gutter: 10, columns: 8 }) { ForEach(this.bgColors, (item: Color, index?: number) => { GridCol() { Row() { Text(`${index}`) } .width('100%') .height('50') } .backgroundColor(item) }) } .width('100%') .height('100%') } }显示效果如下图所示:

图 7 同时设置子组件间水平和垂直方向间距的显示效果
当 gutter 的类型为 GutterOption 时,可以单独设置栅格子组件的水平和垂直间距。此时,x 属性用于设置水平方向的间距,y 属性用于设置垂直方向的间距。示例代码如下:
@Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown, Color.Red, Color.Orange, Color.Yellow, Color.Green ]; build() { // gutter 设置子组件水平方向的间距为 20 vp,垂直方向的间距为 50 vp GridRow({ gutter: { x: 20, y: 50 }, columns: 8 }) { ForEach(this.bgColors, (item: Color, index?: number) => { GridCol() { Row() { Text(`${index}`) } .width('100%') .height('50') } .backgroundColor(item) }) } .width('100%') .height('100%') } }显示效果如下图所示:

图 8 单独设置子组件间水平和垂直方向间距的显示效果
子组件GridCol
GridCol 是 GridRow 组件的子组件,可以通过给 GridCol 传参或者设置属性这两种方式,设置 span(占用列数)、offset(偏移列数)和 order(元素序号)的值。设置 span 的示例代码如下:
// 以 Record 类型数据的方式设置布局参数 // 当断点是 xs 时组件占据 1 个单元格,当断点是 sm 时组件占据 2 个单元格 // 当断点是 md 时组件占据 3 个单元格,当断点是 lg 时组件占据 4 个单元格 let Gspan: Record<string, number> = { xs: 1, sm: 2, md: 3, lg: 4 }; @Entry @Component struct GridSample { build() { Column() { GridRow() { // 组件占据 2 个单元格 GridCol({ span: 2 }) .backgroundColor(Color.Green) .height(50) // 当断点是 xs/sm/md/lg 时分别占据 1/2/3/4 个单元格 GridCol({ span: { xs: 1, sm: 2, md: 3, lg: 4 } }) .backgroundColor(Color.Blue) .height(50) // 通过属性的方式设置组件占据 2 个单元格 GridCol() .span(2) .backgroundColor(Color.Red) .height(50) // 通过 Record 形式,在不同断点下占据不同单元格 GridCol() .span(Gspan) .backgroundColor(Color.Yellow) .height(50) } } } }显示效果如下图所示:

图 9 设置Span之后的显示效果
设置 offset 的示例代码如下:
// 以 Record 类型数据的形式设置布局参数 // 当断点是 xs 时偏移量为 1 个单元格,当断点是 sm 时偏移量为 2 个单元格 // 当断点是 md 时偏移量为 3 个单元格,当断点是 lg 时偏移量为 4 个单元格 let Goffset: Record<string, number> = { xs: 1, sm: 2, md: 3, lg: 4 }; @Entry @Component struct GridSample { build() { GridRow() { // 设置单元格偏移量为 2 个单元格 GridCol({ offset: 2 }) .backgroundColor(Color.Brown) .height(50) // 当断点是 xs / sm / md / lg 时偏移量均为 2 个单元格 GridCol({ offset: { xs: 2, sm: 2, md: 2, lg: 2 } }) .backgroundColor(Color.Blue) .height(50) // 通过 Record 类型数据设置属性,在不同断点下使用不同偏移量 GridCol() .offset(Goffset) .backgroundColor(Color.Red) .height(50) } .height('100%') .width('100%') } }显示效果如下图所示:

图 10 设置offset之后的显示效果
设置 order 的示例代码如下:
// 以 Record 类型数据的方式设置布局参数 // 当断点是 xs 时次序为 1,当断点是 sm 时次序为 2, // 当断点是 md 时次序为 3,当断点是 lg 时次序为 4 let Gorder: Record<string, number> = { xs: 1, sm: 2, md: 3, lg: 4 }; @Entry @Component struct GridSample { build() { GridRow({ columns: 4 }) { // 设置排列次序为 2 GridCol({ order: 2 }) { Text('1') .height('100%') .width('100%') .textAlign(TextAlign.Center) .fontColor(Color.White) } .backgroundColor(Color.Orange) // 断点:xs→1, sm→2, md→3, lg→4 GridCol({ order: { xs: 1, sm: 2, md: 3, lg: 4 } }) { Text('2') .fontColor(Color.Yellow) .height('100%') .width('100%') .textAlign(TextAlign.Center) } .backgroundColor(Color.Brown) // 以属性的方式设置次序为 2 GridCol() { Text('3') .fontColor(Color.Yellow) .height('100%') .width('100%') .textAlign(TextAlign.Center) } .backgroundColor(Color.Green) .order(2) // 以属性的方式设置不同断点下的次序 GridCol() { Text('4') .fontColor(Color.Yellow) .height('100%') .width('100%') .textAlign(TextAlign.Center) } .backgroundColor(Color.Blue) .order(Gorder) } .height(100) } }显示效果如下图所示:

图 11 设置order之后的显示效果
GridCol span
span 是子组件占栅格布局的列数,决定了子组件的宽度,其默认值为 1。当其类型为 number 时,子组件在所有尺寸设备下占用的列数相同。示例代码如下:
@Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown ]; build() { // 设置每行分配 8 个单元格 GridRow({ columns: 8 }) { ForEach(this.bgColors, (color: Color, index?: number) => { // 设置子组件占据的单元格个数为 2 GridCol({ span: 2 }) { Row() { Text(`${index}`) } .width('100%') .height('50vp') .backgroundColor(color) } }) } } }显示效果如下图所示:

图 12 设置span之后的显示效果
当 span 类型为 GridColColumnOption 时,支持在 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备中设置子组件所占列数,并且各个尺寸下列数值可不同。示例代码如下:
@Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown ]; build() { // 设置每行分配 8 个单元格 GridRow({ columns: 8 }) { ForEach(this.bgColors, (color: Color, index?: number) => { // 设置子组件占据的单元格数量: // 当断点为 xs 时占据 1 个单元格, // 当断点为 sm 时占据 2 个单元格, // 当断点为 md 时占据 3 个单元格, // 当断点为 lg 时占据 4 个单元格 GridCol({ span: { xs: 1, sm: 2, md: 3, lg: 4 } }) { Row() { Text(`${index}`) } .width('100%') .height('50vp') } .backgroundColor(color) }) } } }显示效果如下图所示:

图 13 不同尺寸下的显示效果
GridCol offset
offset 表示栅格子组件相对于前一个子组件的偏移列数,默认值为 0。当 offset 类型为 number 时,所有子组件偏移相同列数。示例代码如下:
@Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown ]; build() { GridRow() { ForEach(this.bgColors, (color: Color, index?: number) => { // 设置子组件偏移量为 2 个单元格 GridCol({ offset: 2 }) { Row() { Text(`${index}`) } .width('100%') .height('50vp') } .backgroundColor(color) }) } } }显示效果如下图所示:

图 14 设置offset之后的显示效果
栅格默认分成 12 列,每一个子组件默认占 1 列,当偏移 2 列时,每个子组件及间距共占 3 列,因此一行放 4 个子组件。
当 offset 的类型为 GridColColumnOption 时,支持在 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备中设置子组件所占列数,并且各个尺寸下列数值可不同,示例代码如下:
@Entry @Component struct GridSample { @State bgColors: Color[] = [ Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown ]; build() { GridRow() { ForEach(this.bgColors, (color: Color, index?: number) => { // 设置子组件在不同断点时的偏移量: // xs 偏移 1 个单元格,sm 偏移 2 个单元格, // md 偏移 3 个单元格,lg 偏移 4 个单元格 GridCol({ offset: { xs: 1, sm: 2, md: 3, lg: 4 } }) { Row() { Text('' + index) } .width('100%') .height('50vp') } .backgroundColor(color) }) } } }显示效果如下图所示:

图 15 子组件在不同断点处的偏移量
GridCol order
order 表示栅格子组件的序号,决定了子组件的排列次序:- 当子组件不设置 order 或者设置相同的 order 时,子组件按照代码顺序展示;
- 当子组件设置不同的 order 时,order 较小的组件在前,较大的在后;
- 当子组件部分设置 order,部分不设置 order 时,未设置 order 的子组件依次排序靠前,设置了 order 的子组件按照数值从小到大排列;
- 当 order 类型为 number 时,子组件在任何尺寸下排序次序一致。
order 设置的示例代码如下:
@Entry @Component struct GridSample { build() { GridRow() { // 设置次序为 4 GridCol({ order: 4 }) { Row() { Text('1') } .width('100%') .height('50vp') } .backgroundColor(Color.Red) // 设置次序为 3 GridCol({ order: 3 }) { Row() { Text('2') } .width('100%') .height('50vp') } .backgroundColor(Color.Orange) // 设置次序为 2 GridCol({ order: 2 }) { Row() { Text('3') } .width('100%') .height('50vp') } .backgroundColor(Color.Yellow) // 设置次序为 1 GridCol({ order: 1 }) { Row() { Text('4') } .width('100%') .height('50vp') } .backgroundColor(Color.Green) } } }显示效果如下图所示:

图 16 设置order之后的显示效果
当 order 类型为 GridColColumnOption 时,支持 6 种不同尺寸(xs, sm, md, lg, xl, xxl)设备中设置子组件排序次序。
例如,在 xs 设备中,子组件排列顺序为 1234;在 sm 设备中为 2341;在 md 子组件中排列顺序为 3412;在 lg 子组件中排列顺序为 2431,示例代码如下:
@Entry @Component struct GridSample { build() { GridRow() { // 当处于断点 xs 时次序为 1,当处于断点 sm 时次序为 5, // 当处于断点 md 时次序为 3,当处于断点 lg 时次序为 7 GridCol({ order: { xs: 1, sm: 5, md: 3, lg: 7 } }) { Row() { Text('1') } .width('100%') .height('50vp') } .backgroundColor(Color.Red) // xs:2, sm:2, md:6, lg:1 GridCol({ order: { xs: 2, sm: 2, md: 6, lg: 1 } }) { Row() { Text('2') } .width('100%') .height('50vp') } .backgroundColor(Color.Orange) // xs:3, sm:3, md:1, lg:6 GridCol({ order: { xs: 3, sm: 3, md: 1, lg: 6 } }) { Row() { Text('3') } .width('100%') .height('50vp') } .backgroundColor(Color.Yellow) // xs:4, sm:4, md:2, lg:5 GridCol({ order: { xs: 4, sm: 4, md: 2, lg: 5 } }) { Row() { Text('4') } .width('100%') .height('50vp') } .backgroundColor(Color.Green) } } }显示效果如下图所示:

图 17 不同尺寸设备下不同order的显示效果
栅格组件的嵌套使用
栅格组件也可以嵌套使用,完成一些复杂的布局。在下面实例中,栅格把整个空间分为 12 份;
- 第一层 GridRow 嵌套 GridCol,分为中间大区域以及 footer 区域;
- 第二层 GridRow 嵌套 GridCol,分为 left 和 right 区域;
- 子组件的空间按照上一层父组件的空间划分。
@Entry @Component struct GridRowExample { build() { GridRow() { // 这是一个容器组件,用于创建一个栅格行 GridCol({ span: { sm: 12 } }) { // 在小屏幕设备上(sm)该列将占用 12 个单元格(意味着整行的宽度) GridRow() { // 第一个子列占用 2 个单元格 GridCol({ span: { sm: 2 } }) { Row() { Text('left').fontSize(24) } .justifyContent(FlexAlign.Center) .height('90%') } .backgroundColor('#ff41dbaa') // 第二个子列占用 10 个单元格 GridCol({ span: { sm: 10 } }) { Row() { Text('right').fontSize(24) } .justifyContent(FlexAlign.Center) .height('90%') } .backgroundColor('#ff4168db') } .backgroundColor('#19000000') } // 第二个栅格列占用 12 个单元格,容纳一个显示“footer”的文本 GridCol({ span: { sm: 12 } }) { Row() { Text('footer') .width('100%') .textAlign(TextAlign.Center) } .width('100%') .height('10%') .backgroundColor(Color.Pink) } } .width('100%') .height(300) } }显示效果如下图所示:

图 18 栅格组件的嵌套使用
综上所述,栅格组件提供了丰富的自定义能力,功能异常灵活和强大。只需明确栅格在不同断点下的 columns、margin、gutter 及 span 等参数,即可确定最终布局,而无须关心具体的设备类型及设备状态(如横竖屏)等。