美文网首页
栅格布局(GridRow/GridCol)

栅格布局(GridRow/GridCol)

作者: SeanLink | 来源:发表于2023-12-13 14:38 被阅读0次

    栅格布局(GridRow/GridCol)

    GridRow为栅格容器组件,需与栅格子组件GridCol在栅格布局场景中联合使用。

    栅格容器GridRow

    栅格系统断点

    栅格系统以设备的水平宽度(屏幕密度像素值,单位vp)作为断点依据,定义设备的宽度类型,形成了一套断点规则。开发者可根据需求在不同的断点区间实现不同的页面布局效果。

    断点名称 设备描述
    xs 最小宽度类型设备。
    sm 小宽度类型设备。
    md 中等宽度类型设备。
    lg 大宽度类型设备。
    xl 特大宽度类型设备。
    xxl 超大宽度类型设备。
    • 针对断点位置,开发者根据实际使用场景,通过一个单调递增数组设置。由于breakpoints最多支持六个断点,单调递增数组长度最大为5。

      表示启用xs、sm、md、lg、xl共5个断点,小于320vp为xs,320vp-520vp为sm,520vp-840vp为md,840vp-1080vp为lg,大于1080vp为xl

      breakpoints: {value: ['320vp', '520vp', '840vp', '1080vp']}
      
    栅格的默认列数12列,可以通过断点设置将应用宽度分成六个区间,在各区间中,每个栅格子元素占用的列数均不同。
    • span 可以设置栅格占用多少列
    @State bgColors: Color[] = [Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown];
    ...
    GridRow({
      breakpoints: {
        value: ['200vp', '300vp', '400vp', '500vp', '600vp'],
        reference: BreakpointsReference.WindowSize
      }
    }) {
       ForEach(this.bgColors, (color, index) => {
         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)
       })
    }                                                                     
    
    0000000000011111111.20231204103822.47257113918867463806512134720145.gif

    布局的总列数

    GridRow中通过columns设置栅格布局的总列数。

    • columns默认值为12,即在未设置columns时,任何断点下,栅格布局被分成12列。
    @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];
    ...
    GridRow() {
      ForEach(this.bgColors, (item, index) => {
        GridCol() {
          Row() {
            Text(`${index + 1}`)
          }.width('100%').height('50')
        }.backgroundColor(item)
      })
    }           
    
    18c665aed31.png
    • 当columns为自定义值,栅格布局在任何尺寸设备下都被分为columns列
    @State bgColors: Color[] = [Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown];
    @State currentBp: string = 'unknown';
    ...
    Row() {
      GridRow({ columns: 4 }) {
        ForEach(this.bgColors, (item, index) => {
          GridCol() {
            Row() {
              Text(`${index + 1}`)
            }.width('100%').height('50')
          }.backgroundColor(item)
        })
      }
      .width('100%').height('100%')
      .onBreakpointChange((breakpoint) => {
        this.currentBp = breakpoint
      })
    }
    .height(160)
    .border({ color: Color.Blue, width: 2 })
    .width('90%')
    
    Row() {
      GridRow({ columns: 8 }) {
        ForEach(this.bgColors, (item, index) => {
          GridCol() {
            Row() {
              Text(`${index + 1}`)
            }.width('100%').height('50')
          }.backgroundColor(item)
        })
      }
      .width('100%').height('100%')
      .onBreakpointChange((breakpoint) => {
        this.currentBp = breakpoint
      })
    }
    .height(160)
    .border({ color: Color.Blue, width: 2 })
    .width('90%')
    
    18c665d2128.png
    • 当columns类型为GridRowColumnOption时,支持下面六种不同尺寸(xs, sm, md, lg, xl, xxl)设备的总列数设置,各个尺寸下数值可不同。
    @State bgColors: Color[] = [Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown]
    GridRow({ columns: { sm: 4, md: 8 }, breakpoints: { value: ['200vp', '300vp', '400vp', '500vp', '600vp'] } }) {
      ForEach(this.bgColors, (item, index) => {
        GridCol() {
          Row() {
            Text(`${index + 1}`)
          }.width('100%').height('50')
        }.backgroundColor(item)
      })
    }
    
    option.gif

    排列方向

    • 子组件默认从左往右排列。
    GridRow({ direction: GridRowDirection.Row }){}
    
    
    18c6663393d.png
    • 子组件从右往左排列。

      GridRow({ direction: GridRowDirection.RowReverse }){}
      
    18c66636f05.png

    子组件间距

    GridRow中通过gutter属性设置子元素在水平和垂直方向的间距。

    • 当gutter类型为number时,同时设置栅格子组件间水平和垂直方向边距且相等。下例中,设置子组件水平与垂直方向距离相邻元素的间距为10。
     GridRow({ gutter: 10 }){}
    
    18c6664da23.png
    • 当gutter类型为GutterOption时,单独设置栅格子组件水平垂直边距,x属性为水平方向间距,y为垂直方向间距。

      GridRow({ gutter: { x: 20, y: 50 } }){}
      
    18c6665291d.png

    子组件GridCol

    GridCol组件作为GridRow组件的子组件,通过给GridCol传参或者设置属性两种方式,设置span(占用列数),offset(偏移列数),order(元素序号)的值。

    • 设置span。
    GridCol({ span: 2 }){}
    GridCol({ span: { xs: 1, sm: 2, md: 3, lg: 4 } }){}
    GridCol(){}.span(2)
    GridCol(){}.span({ xs: 1, sm: 2, md: 3, lg: 4 })
    
    • 设置offset。
    GridCol({ offset: 2 }){}
    GridCol({ offset: { xs: 2, sm: 2, md: 2, lg: 2 } }){}
    GridCol(){}.offset(2)
    GridCol(){}.offset({ xs: 1, sm: 2, md: 3, lg: 4 }) 
    
    • 设置order。
    GridCol({ order: 2 }){}
    GridCol({ order: { xs: 1, sm: 2, md: 3, lg: 4 } }){}
    GridCol(){}.order(2)
    GridCol(){}.order({ xs: 1, sm: 2, md: 3, lg: 4 })
    

    span

    子组件占栅格布局的列数,决定了子组件的宽度,默认为1。

    • 当类型为number时,子组件在所有尺寸设备下占用的列数相同。

      @State bgColors: Color[] = [Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown];
      ...
      GridRow({ columns: 8 }) {
        ForEach(this.bgColors, (color, index) => {
          GridCol({ span: 2 }) {      
            Row() {
              Text(`${index}`)
            }.width('100%').height('50vp')          
          }
          .backgroundColor(color)
        })
      }                
      
    18c66675bf2.png
    • 当类型为GridColColumnOption时,支持六种不同尺寸(xs, sm, md, lg, xl, xxl)设备中子组件所占列数设置,各个尺寸下数值可不同。

      @State bgColors: Color[] = [Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown];
      ...
      GridRow({ columns: 8 }) {
        ForEach(this.bgColors, (color, index) => {
          GridCol({ span: { xs: 1, sm: 2, md: 3, lg: 4 } }) {      
            Row() {
              Text(`${index}`)
            }.width('100%').height('50vp')          
          }
          .backgroundColor(color)
        })
      }                
      
    span.gif

    offset

    栅格子组件相对于前一个子组件的偏移列数,默认为0。

    • 当类型为number时,子组件偏移相同列数。
    @State bgColors: Color[] = [Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown];
    ...
    GridRow() {
      ForEach(this.bgColors, (color, index) => {
        GridCol({ offset: 2 }) {      
          Row() {
            Text('' + index)
          }.width('100%').height('50vp')          
        }
        .backgroundColor(color)
      })
    }                
    
    18c666dfe2e.png

    栅格默认分成12列,每一个子组件默认占1列,偏移2列,每个子组件及间距共占3列,一行放四个子组件。

    • 当类型为GridColColumnOption时,支持六种不同尺寸(xs, sm, md, lg, xl, xxl)设备中子组件所占列数设置,各个尺寸下数值可不同。
    @State bgColors: Color[] = [Color.Red, Color.Orange, Color.Yellow, Color.Green, Color.Pink, Color.Grey, Color.Blue, Color.Brown];
    ...
    
    GridRow() {
      ForEach(this.bgColors, (color, index) => {
        GridCol({ offset: { xs: 1, sm: 2, md: 3, lg: 4 } }) {      
          Row() {
            Text('' + index)
          }.width('100%').height('50vp')          
        }
        .backgroundColor(color)
      })
    }                 
    

    order

    栅格子组件的序号,决定子组件排列次序。当子组件不设置order或者设置相同的order, 子组件按照代码顺序展示。当子组件设置不同的order时,order较小的组件在前,较大的在后。

    当子组件部分设置order,部分不设置order时,未设置order的子组件依次排序靠前,设置了order的子组件按照数值从小到大排列。

    • 当类型为number时,子组件在任何尺寸下排序次序一致。

      GridRow() {
        GridCol({ order: 4 }) {
          Row() {
            Text('1')
          }.width('100%').height('50vp')
        }.backgroundColor(Color.Red)
        GridCol({ order: 3 }) {
          Row() {
            Text('2')
          }.width('100%').height('50vp')
        }.backgroundColor(Color.Orange)
        GridCol({ order: 2 }) {
          Row() {
            Text('3')
          }.width('100%').height('50vp')
        }.backgroundColor(Color.Yellow)
        GridCol({ order: 1 }) {
          Row() {
            Text('4')
          }.width('100%').height('50vp')
        }.backgroundColor(Color.Green)
      }            
      
    18c666f570c.png
    • 当类型为GridColColumnOption时,支持六种不同尺寸(xs, sm, md, lg, xl, xxl)设备中子组件排序次序设置。在xs设备中,子组件排列顺序为1234;sm为2341,md为3412,lg为2431。
    GridRow() {
      GridCol({ order: { xs:1, sm:5, md:3, lg:7}}) {
        Row() {
          Text('1')
        }.width('100%').height('50vp')
      }.backgroundColor(Color.Red)
      GridCol({ order: { xs:2, sm:2, md:6, lg:1} }) {
        Row() {
          Text('2')
        }.width('100%').height('50vp')
      }.backgroundColor(Color.Orange)
      GridCol({ order: { xs:3, sm:3, md:1, lg:6} }) {
        Row() {
          Text('3')
        }.width('100%').height('50vp')
      }.backgroundColor(Color.Yellow)
      GridCol({ order: { xs:4, sm:4, md:2, lg:5} }) {
        Row() {
          Text('4')
        }.width('100%').height('50vp')
      }.backgroundColor(Color.Green)
    } 
    
    order.gif

    栅格组件的嵌套使用

    栅格组件也可以嵌套使用,完成一些复杂的布局。

    以下示例中,栅格把整个空间分为12份。第一层GridRow嵌套GridCol,分为中间大区域以及“footer”区域。第二层GridRow嵌套GridCol,分为“left”和“right”区域。子组件空间按照上一层父组件的空间划分,粉色的区域是屏幕空间的12列,绿色和蓝色的区域是父组件GridCol的12列,依次进行空间的划分。

    @Entry
    @Component
    struct GridRowExample {
      build() {
        GridRow() {
          GridCol({ span: { sm: 12 } }) {
            GridRow() {
              GridCol({ span: { sm: 2 } }) {
                Row() {
                  Text('left').fontSize(24)
                }
                .justifyContent(FlexAlign.Center)
                .height('90%')
              }.backgroundColor('#ff41dbaa')
    
              GridCol({ span: { sm: 10 } }) {
                Row() {
                  Text('right').fontSize(24)
                }
                .justifyContent(FlexAlign.Center)
                .height('90%')
              }.backgroundColor('#ff4168db')
            }
            .backgroundColor('#19000000')
            .height('100%')
          }
    
          GridCol({ span: { sm: 12 } }) {
            Row() {
              Text('footer').width('100%').textAlign(TextAlign.Center)
            }.width('100%').height('10%').backgroundColor(Color.Pink)
          }
        }.width('100%').height(300)
      }
    }
    
    18c66705c2c.png

    相关文章

      网友评论

          本文标题:栅格布局(GridRow/GridCol)

          本文链接:https://www.haomeiwen.com/subject/mkgbgdtx.html