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

鸿蒙~栅格布局(GridRow/GridCol)

作者: 胡修波 | 来源:发表于2024-01-11 13:33 被阅读0次

    概述:

    栅格布局是一种通用的辅助定位工具,对移动设备的界面设计有较好的借鉴作用。主要优势包括:

    • 提供可循的规律:栅格布局可以为布局提供规律性的结构,解决多尺寸多设备的动态布局问题。通过将页面划分为等宽的列数和行数,可以方便地对页面元素进行定位和排版。
    • 统一的定位标注:栅格布局可以为系统提供一种统一的定位标注,保证不同设备上各个模块的布局一致性。这可以减少设计和开发的复杂度,提高工作效率。
    • 灵活的间距调整方法:栅格布局可以提供一种灵活的间距调整方法,满足特殊场景布局调整的需求。通过调整列与列之间和行与行之间的间距,可以控制整个页面的排版效果。
    • 自动换行和自适应:栅格布局可以完成一对多布局的自动换行和自适应。当页面元素的数量超出了一行或一列的容量时,他们会自动换到下一行或下一列,并且在不同的设备上自适应排版,使得页面布局更加灵活和适应性强。

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

    栅格容器GridRow

    • 栅格系统断点 :
      栅格系统以设备的水平宽度(屏幕密度像素值,单位vp)作为断点依据,定义设备的宽度类型,形成了一套断点规则。开发者可根据需求在不同的断点区间实现不同的页面布局效果
      1、栅格系统默认断点将设备宽度分为xs、sm、md、lg四类
      2、在GridRow栅格组件中,允许开发者使用breakpoints自定义修改断点的取值范围,最多支持6个断点,除了默认的四个断点外,还可以启用xl,xxl两个断点,支持六种不同尺寸(xs, sm, md, lg, xl, xxl)设备的布局设置
    breakpoints: {value: ['100vp', '200vp']}
    

    表示启用xs、sm、md共3个断点,小于100vp为xs,100vp-200vp为sm,大于200vp为md。

    例如,使用栅格的默认列数12列,通过断点设置将应用宽度分成六个区间,在各区间中,每个栅格子元素占用的列数均不同。

    @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)
       })
    } 
    
    • 布局的总列数,默认12列
    @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 }) { // 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%')
    }
    .height(160)
    .border({ color: Color.Blue, width: 2 })
    .width('90%')
    
    • 排列方向
      栅格布局中,可以通过设置GridRow的direction属性来指定栅格子组件在栅格容器中的排列方向。该属性可以设置为GridRowDirection.Row(从左往右排列)或GridRowDirection.RowReverse(从右往左排列)
    GridRow({ direction: GridRowDirection.Row }){}
    
    • 子组件间距
      GridRow中通过gutter属性设置子元素在水平和垂直方向的间距
     GridRow({ gutter: 10 }){}
    

    子组件GridCol

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

    • span:子组件占栅格布局的列数,决定了子组件的宽度,默认为1
    GridCol({ span: 2 }){}
    
    • offset: 栅格子组件相对于前一个子组件的偏移列数,默认为0。
    @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)
      })
    }                
    
    • order :栅格子组件的序号,决定子组件排列次序。当子组件不设置order或者设置相同的order, 子组件按照代码顺序展示。当子组件设置不同的order时,order较小的组件在前,较大的在后
    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)
    }            
    

    相关文章

      网友评论

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

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