【HarmonyOS】掌握布局组件,提升应用体验

news2024/9/20 20:51:28

       从今天开始,博主将开设一门新的专栏用来讲解市面上比较热门的技术 “鸿蒙开发”,对于刚接触这项技术的小伙伴在学习鸿蒙开发之前,有必要先了解一下鸿蒙,从你的角度来讲,你认为什么是鸿蒙呢?它出现的意义又是什么?鸿蒙仅仅是一个手机操作系统吗?它的出现能够和Android和IOS三分天下吗?它未来的潜力能否制霸整个手机市场呢?

抱着这样的疑问和对鸿蒙开发的好奇,让我们开始今天对布局组件的掌握吧!

目录

布局组件

Column与Row组件(排列布局)

Stack组件(层叠布局)

Flex组件(弹性布局)

RelativeContainer组件(相对布局)

List组件(创建列表)

Grid组件(创建网格)


布局组件

在 ArkTS 中,布局组件是一种用于管理和布置其他组件的特殊组件。它们用于定义用户界面的结构和排列方式。以下是ArkTS的通用属性:

名称参数说明描述
widthLength设置组件自身的宽度
heightLength设置组件自身的高度
sizeLength设置高宽尺寸
paddingPadding | Length设置内边距属性
marginMargin | Length设置外边距属性
constraintSizeLength设置约束尺寸,组件布局时进行尺寸范围限制

Column与Row组件(排列布局)

Column与Row是鸿蒙开发中最最常用的布局组件,它们分别用于垂直和水平方向上的排列和布局子组件,下面是该两个组件的使用区别:

Column(列)

Column 组件将子组件在垂直方向上依次排列。子组件按照从上到下的顺序布局,每个子组件占据一行。Column 组件会根据子组件的大小自动调整自身的高度以适应内容。

Row(行)

Row 组件将子组件在水平方向上依次排列。子组件按照从左到右的顺序布局,每个子组件占据一列。Row 组件会根据子组件的大小自动调整自身的宽度以适应内容。

因此,Column 和 Row 的主要区别在于排列方向和布局方式。如果你想要在垂直方向上依次排列子组件,可以使用 Column 组件;如果你想要在水平方向上依次排列子组件,可以使用 Row 组件。以下是使用Column和Row的基本用法:

@Entry
@Component
struct TEST {
  build() {
    Column({ space: 10 }){
      Row({ space: 10 }){
        Row(){
        }
        .width('33%')
        .height(160)
        .backgroundColor('red')
        .layoutWeight(1)
        Row(){
        }
        .width('33%')
        .height(160)
        .backgroundColor('green')
        .layoutWeight(1)
        Row(){
        }
        .width(100)
        .height(160)
        .backgroundColor('blue')
      }
      .width('100%')
      .height(160)

      Column({ space: 10 }){
        Row().width('100%').backgroundColor(Color.Gray).layoutWeight(1)
        Row().width('100%').backgroundColor(Color.Red).layoutWeight(2)
      }
      .width('100%')
      .height(160)
    }
    .width('100%')
    .height('100%')
    .justifyContent(FlexAlign.Center)
  }
}

呈现的结果如下:

Stack组件(层叠布局)

层叠布局(StackLayout)用于在屏幕上预留一块区域来显示组件中的元素,提供元素可以重叠的布局。层叠布局通过Stack容器组件实现位置的固定定位与层叠,容器中的子元素(子组件)依次入栈,后一个子元素覆盖前一个子元素,子元素可以叠加,也可以设置位置。

层叠布局具有较强的页面层叠、位置定位能力,其使用场景有广告、卡片层叠效果等。如下:

Stack组件通过alignContent参数实现位置的相对移动。如下表所示,支持九种对齐方式:

名称

描述

TopStart

顶部起始端。

Top

顶部横向居中。

TopEnd

顶部尾端。

Start

起始端纵向居中。

Center

横向和纵向居中。

End

尾端纵向居中。

BottomStart

底部起始端。

Bottom

底部横向居中。

BottomEnd

底部尾端。

以下是借助Stack组件进行的案例,代码如下:

@Entry
@Component
struct TEST {
  @State list: number[] = [1, 2, 3]
  build() {
    Column(){
      Stack({ alignContent: Alignment.BottomEnd }){
        Stack({ alignContent: Alignment.TopStart}){
          Column(){
            List({ space: 10 }){
              ForEach(this.list,(item)=>{
                ListItem(){
                  Text(`${item}`)
                    .fontSize(30)
                    .width('100%')
                    .backgroundColor('#eee').height(50).textAlign(TextAlign.Center)
                }
              })
            }
            .margin({ bottom: 70 })
          }
          .margin({ top: 60 })
          .height('100%')
          Row(){
            Text('HarmonyOS')
              .fontSize(30)
              .fontColor(Color.White)
              .width('100%')
              .textAlign(TextAlign.Center)
          }
          .width('100%')
          .backgroundColor(Color.Orange)
          .height(50)
        }
        Button(){
          Text('+').fontSize(40).fontColor(Color.White)
        }
        .width(80)
        .height(80)
        .onClick( ()=> {
          this.list.push(this.list[this.list.length - 1] + 1)
        })
        .margin({ right: 10, bottom: 10 })
      }
    }
    .width('100%')
    .height('100%')
  }
}

最终呈现的结果如下:

Flex组件(弹性布局)

弹性布局(Flex)提供更加有效的方式对容器中的子元素进行排列、对齐和分配剩余空间。容器默认存在主轴与交叉轴,子元素默认沿主轴排列,子元素在主轴方向的尺寸称为主轴尺寸,在交叉轴方向的尺寸称为交叉轴尺寸。弹性布局在开发场景中用例特别多,比如页面头部导航栏的均匀分布、页面框架的搭建、多行数据的排列等等。

主轴:Flex组件布局方向的轴线,子元素默认沿着主轴排列。主轴开始的位置称为主轴起始点,结束位置称为主轴结束点。
交叉轴:垂直于主轴方向的轴线。交叉轴开始的位置称为交叉轴起始点,结束位置称为交叉轴结束点。

以下是flex常见的使用参数:

参数名参数类型必填默认值参数描述
directionFlexDirectionFlexDirection.Row主轴方向
wrapFlexWrapFlexWrap.NoWrap确认容器是单行/列还是多行
justifyContentFlexAlignFlexAlign.Start子组件在flex容器主轴上对齐格式
alignItemsItemAlignItemAlign.Start子组件在flex容器交叉轴上对齐格式
alignContentFlexAlignFlexAlign.Start多行内容的对齐格式。wrap多行下生效

以下是通过 FlexDirection 来更改方向的操作:

@Entry
@Component
struct TEST {
  build() {
    Column({ space: 20 }){
      // 主轴为水平方向,子组件从起始端沿着水平方向开始排布。
      Flex({ direction: FlexDirection.Row }) {
        Text('1').width('33%').height(50).backgroundColor(0xF5DEB3)
        Text('2').width('33%').height(50).backgroundColor(0xD2B48C)
        Text('3').width('33%').height(50).backgroundColor(0xF5DEB3)
      }
      .height(70)
      .width('90%')
      .padding(10)
      .backgroundColor(0xAFEEEE)

      // 主轴为水平方向,子组件从终点端沿着FlexDirection. Row相反的方向开始排布。
      Flex({ direction: FlexDirection.RowReverse }) {
        Text('1').width('33%').height(50).backgroundColor(0xF5DEB3)
        Text('2').width('33%').height(50).backgroundColor(0xD2B48C)
        Text('3').width('33%').height(50).backgroundColor(0xF5DEB3)
      }
      .height(70)
      .width('90%')
      .padding(10)
      .backgroundColor(0xAFEEEE)

      // 主轴为垂直方向,子组件从起始端沿着垂直方向开始排布。
      Flex({ direction: FlexDirection.Column }) {
        Text('1').width('100%').height(50).backgroundColor(0xF5DEB3)
        Text('2').width('100%').height(50).backgroundColor(0xD2B48C)
        Text('3').width('100%').height(50).backgroundColor(0xF5DEB3)
      }
      .height(70)
      .width('90%')
      .padding(10)
      .backgroundColor(0xAFEEEE)

      // 主轴为垂直方向,子组件从终点端沿着FlexDirection. Column相反的方向开始排布。
      Flex({ direction: FlexDirection.ColumnReverse }) {
        Text('1').width('100%').height(50).backgroundColor(0xF5DEB3)
        Text('2').width('100%').height(50).backgroundColor(0xD2B48C)
        Text('3').width('100%').height(50).backgroundColor(0xF5DEB3)
      }
      .height(70)
      .width('90%')
      .padding(10)
      .backgroundColor(0xAFEEEE)
    }
    .width('100%')
    .height('100%')
  }
}

最终呈现的结果如下:

当然弹性布局方面还有许多其他的操作,这里就不再赘述了,详情请参考 文档  

RelativeContainer组件(相对布局)

相对布局组件用于复杂场景中元素对齐的布局,支持容器内的子元素设置相对位置关系,子元素支持指定兄弟元素作为锚点,也支持指定父容器作为锚点,基于锚点做相对位置布局,下图表示相对布局的概念图,虚线表示位置的依赖关系:

通过以下的案例代码来学习相对布局的形成:

@Entry
@Component
struct TEST {
  build() {
    Column(){
      // RelativeContainer必须包含子元素
      // RelativeContainer固定的id就是 __container__
      RelativeContainer(){
        // RelativeContainer里面的子元素必须配置id属性
        Text("1")
          .width(100)
          .height(100)
          .fontSize(30)
          .alignRules({ // 当前容器的属性
            right: {
              anchor: "__container__", // 锚点,传入容器id
              align: HorizontalAlign.End // 相对于锚点位置的布局
             }
          })
          .backgroundColor(Color.Blue)
          .id('test1')

        Text("2")
          .width(100)
          .height(100)
          .fontSize(30)
          .alignRules({ // 当前容器的属性
            middle: {
              anchor: "__container__", // 锚点,传入容器id
              align: HorizontalAlign.Center // 相对于锚点位置的布局
            }
          })
          .backgroundColor(Color.Orange)
          .id('test2')

        Text("3")
          .width(100)
          .height(100)
          .fontSize(30)
          .alignRules({ // 当前容器的属性
            bottom: {
              anchor: "__container__", // 锚点,传入容器id
              align: VerticalAlign.Bottom // 相对于锚点位置的布局
            },
            right: {
              anchor: "__container__", // 锚点,传入容器id
              align: HorizontalAlign.End // 相对于锚点位置的布局
            }
          })
          .backgroundColor(Color.Red)
          .id('test3')

        // 相对于 2 进行布局,使其在2的正上方
        Text("4")
          .width(100)
          .height(100)
          .fontSize(30)
          .alignRules({ // 当前容器的属性
            bottom: {
              anchor: "test2", // 锚点,传入容器id
              align: VerticalAlign.Top // 相对于锚点位置的布局
            },
            left: {
              anchor: "test2", // 锚点,传入容器id
              align: HorizontalAlign.Start // 相对于锚点位置的布局
            }
          })
          .backgroundColor(Color.Green)
          .id('test4')
          .offset({ // 微调位置
            y: -20,
            x: 0
          })
      }
      .width(300)
      .height(300)
      .border({
        width: 1,
        color: Color.Red
      })
    }
    .width('100%')
    .height('100%')
    .justifyContent(FlexAlign.Center)
  }
}

最终呈现的结果如下:

List组件(创建列表)

列表是一种复杂的容器,当列表项达到一定数量,内容超过屏幕大小时,可以自动提供滚动功能。它适合用于呈现同类数据类型或数据类型集,例如图片和文本。在列表中显示数据集合是许多应用程序中的常见要求(如通讯录、音乐列表、购物清单等)。其主要使用的参数如下:

参数名

参数类型

必填

参数描述

space

number | string

子组件主轴方向的间隔。

initialIndex

number

设置当前List初次加载时视口起始位置显示的item的索引值。

scroller

Scroller

可滚动组件的控制器。用于与可滚动组件进行绑定。

以下是使用List组件的案例:

@Entry
@Component
struct TEST {
  list: number[] = [1, 2, 3, 4, 5, 6, 7]

  build() {
    Column(){
      List({ space: 20 }){
        ForEach(this.list,(item) => {
          ListItem(){
            Text(`${item}`)
              .textAlign(TextAlign.Center)
              .width('100%')
              .height(100)
              .fontSize(30)
          }
          .backgroundColor(0xffffff)
        })
      }
      .listDirection(Axis.Vertical) // 配置list显示方向
      .scrollBar(BarState.Auto) // 显示滚动条
      .padding(10)
      .divider({
        strokeWidth: 5,
        color: Color.Red,
        startMargin: 20,
        endMargin: 20
      })
    }
    .backgroundColor('#cccccc')
    .width('100%')
    .height('100%')
  }
}

最终呈现的效果如下:

Grid组件(创建网格)

网格布局是由“行”和“列”分割的单元格所组成,通过指定“项目”所在的单元格做出各种各样的布局。网格布局具有较强的页面均分能力,子组件占比控制能力,是一种重要自适应布局,其使用场景有九宫格图片展示、日历、计算器等。

名称描述名称描述
columnsTemplate设置当前网格布局列的数量rowsTemplate设置当前网格布局行的数量
columnsGap设置列与列的间距。rowsGap设置行与行的间距。
scrollBar设置滚动条状态。scrollBarColor设置滚动条的颜色。
scrollBarWidth设置滚动条的宽度。cachedCount设置预加载的GridItem的数量,只在LazyForEach中生效。
editMode设置Grid是否进入编辑模式layoutDirection设置布局的主轴方向。
minCount示可显示的最小行/列数。cellLength表示一行的高度/一列的宽度
multiSelectable是否开启鼠标框选。supportAnimation是否支持动画。

基础按钮如下:

@Entry
@Component
struct TEST {
  build() {
    Column(){
      Grid(){
        GridItem(){
          Text("1")
            .fontSize(16).fontColor(Color.White).backgroundColor('red')
            .width('100%').height('100%').textAlign(TextAlign.Center)
        }
        .rowStart(1)
        .rowEnd(2)
        GridItem(){
          Text("2")
            .fontSize(16).fontColor(Color.White).backgroundColor('red')
            .width('100%').height('100%').textAlign(TextAlign.Center)
        }
        .columnStart(2)
        .columnEnd(3)
        GridItem(){
          Text("3")
            .fontSize(16).fontColor(Color.White).backgroundColor('red')
            .width('100%').height('100%').textAlign(TextAlign.Center)
        }
        GridItem(){
          Text("4")
            .fontSize(16).fontColor(Color.White).backgroundColor('red')
            .width('100%').height('100%').textAlign(TextAlign.Center)
        }
        GridItem(){
          Text("5")
            .fontSize(16).fontColor(Color.White).backgroundColor('red')
            .width('100%').height('100%').textAlign(TextAlign.Center)
        }
        GridItem(){
          Text("6")
            .fontSize(16).fontColor(Color.White).backgroundColor('red')
            .width('100%').height('100%').textAlign(TextAlign.Center)
        }
        .columnStart(2)
        .columnEnd(3)
      }
      .columnsTemplate('1fr 1fr 1fr') // 显示3列
      .columnsGap(10)
      .rowsTemplate('1fr 2fr 1fr') // 显示3行 ,第二行宽度占总宽度二分之一
      .rowsGap(10)
      .height(300)
    }
  }
}

呈现的效果如下所示:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1398813.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

知识点 高精度运算

1.基础知识: int是一个机器字长,在32位机器上是32位,则表示范围是[-,-1],可表示的最大整数不会超过。 long long是两个机器字长,表示范围是[-,-1],可表示的最大整数不会超过。 2.适用于需要表示的数据过大…

C++实战:实现生命游戏

文章目录 一、实战概述二、实战步骤(一)编写生命头文件(二)创建生命实现文件(三)编写工具头文件(四)编写工具实现文件(五)编写主程序文件(六&…

wordcloud,一个超强的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个超强的 Python 库 - wordcloud。 Github地址:https://github.com/amueller/word_cloud 词云图是一种独特而引人注目的数据可视化方式,通常用于显示…

第35集《佛法修学概要》

己四 、 精进度 分三:庚一、 精进自性。庚 二、趣入修习精进方便。 庚三、修习精进差别内容 请大家打开讲义第九十四页,我们看己四,精进度。 当我们从人天乘一个好人的阶段提升到一种菩萨道的修学,我们就要注意两个重点了。在我…

什么是内网穿透?

简介: 书面来说:内网穿透是一种网络技术,用于将内部私有网络中的服务暴露给公共网络,使得外部网络可以通过公网访问内网的服务。通常情况下,内网中的设备和服务由于位于私有网络中,无法直接通过公网IP进行…

9.1 Maven项目管理(❤❤❤❤)

9.1 Maven项目管理 1. Maven介绍2. 创建Maven项目2.1 创建2.2 结构分析3. Maven依赖管理3.1 简介3.2 设置下载镜像仓库4. 本地仓库与中央仓库5. Maven生命周期6. Maven插件技术6.1 build标签7. maven属性管理

Django从入门到精通(一)

目录 一、Django环境搭建与命令 1.1、安装 1.2、命令行 创建项目 编写代码 运行 app概念 1.3、Pycharm创建项目 1.4、虚拟环境 创建虚拟环境 - 命令行 介绍 操作 基本问题 Pycharm 项目虚拟环境 django虚拟环境【安装django最新版本】 django虚拟环境【安装指…

《软件方法》强化自测题-杂项(3)-少林足球巴别塔-不属于“软件方法建模师”考察范围

DDD领域驱动设计批评文集 做强化自测题获得“软件方法建模师”称号 《软件方法》各章合集 本套自测题不属于“软件方法建模师”考察范围。 自测链接:https://www.101test.com/cand/index?paperIdQR6CGK 1. [单选] 著名歌曲《橄榄树》(不要问我从那…

端口映射的定义、特点、场景、实例、常见问题回答(Port Mapping)

目 录 一、端口映射(Port Mapping) 二、端口映射应用场景(什么时候用到端口映射) (一)、使用端口映射的条件 (二)使用端口映射的具体场景 三、端口映射技术的特点 …

内网安全管理系统(保密管理系统)

在当今信息化的时代,企业的内网已经成为其核心资产的重要组成部分。 随着企业的快速发展和信息化程度的提升,内网安全问题日益凸显,如何保障内网的安全和机密信息的保密性,已经成为企业亟待解决的问题。 内网安全管理系统(保密管…

Docker项目部署()

1.创建文件夹tools mkdir tools 配置阿里云 Docker Yum 源 : yum install - y yum - utils device - mapper - persistent - data lvm2 yum - config - manager -- add - repo http://mirrors.aliyun.com/docker- ce/linux/centos/docker - ce.repo 更新 yum 缓存 yum makec…

大路灯和护眼台灯哪个好?2024五款大路灯推荐

家用照明发展至今,从古时的匡衡凿壁借光读书,到后面的油灯、蜡烛等照明方式,再到近代的普通白炽灯,荧光灯、LED等电致发光灯具,发展到现在,科技在进步,文明在升级,照明灯具早已不再仅…

各种Linux版本安装Docker

文章目录 一、Ubuntu 20.04.61. 网卡和DNS配置2. Docker安装 二、CentOS Linux 7.91. 网卡和DNS配置2. Docker安装 三、Alibaba Cloud Linux 31. DNS配置2. repo说明3. Docker安装 四、验证是否安装成功 一、Ubuntu 20.04.6 1. 网卡和DNS配置 /etc/netplan 找到 *.yaml 文件 …

YOLOv8全网首发:新一代高效可形变卷积DCNv4如何做二次创新?高效结合SPPF

💡💡💡本文独家改进:DCNv4更快收敛、更高速度、更高性能,与YOLOv8 SPPF高效结合 收录 YOLOv8原创自研 https://blog.csdn.net/m0_63774211/category_12511737.html?spm=1001.2014.3001.5482 💡💡💡全网独家首发创新(原创),适合paper !!! 💡💡💡…

bgp选路

完成基础配置后: 配置bgp(如r2): 全布配置与重发布完成后:全网可达 起源属性修改选路:

LeetCode 0082.删除排序链表中的重复元素 II:模拟

【LetMeFly】82.删除排序链表中的重复元素 II:模拟 力扣题目链接:https://leetcode.cn/problems/remove-duplicates-from-sorted-list-ii/ 给定一个已排序的链表的头 head , 删除原始链表中所有重复数字的节点,只留下不同的数字…

2023年十款开源测试开发工具推荐(自动化、性能、造数据、流量复制)

1、AutoMeter-API 自动化测试平台 AutoMeter 是一款针对分布式服务,微服务 API 做功能和性能一体化的自动化测试平台,一站式提供发布单元,API,环境,用例,前置条件,场景,计划&#xf…

家教上门助教小程序源码,家教小程序,家教系统,家教app,家教源码

家教上门助教小程序源码,家教小程序,家教系统,家教app,家教源码 推荐使用宝塔面板Linux NginxPHPMYSQL 支持家教老师筛选 支持家教人员入住 支持购买课程 支持教学资讯 支持订单课程

剪映导入素材全是绿屏解决方案

自己导入的视频或者是使用素材库里面的素材导入,结果都是一样全都是绿屏 网上找到原因是:兼容性或者软件的问题。 结果方案 : 菜单--全局设置 全局设置--性能。 把启用硬件加速编码和启动硬件加速解码俩个复选框取消掉!重启一下…

某马头条——day06

自媒体文章上下架 使用消息队列在自媒体下架时通知文章微服务。 kafka概述 kafka环境搭建 docker pull zookeeper:3.4.14 docker run -d --name zookeeper -p 2181:2181 zookeeper:3.4.14 安装kafka docker pull wurstmeister/kafka:2.12-2.3.1 docker run -d --name kafka…