ArkUI极简教程03:容器视图的使用(上)

在前两个章节中,我们接触了Text文本视图和Image图片视图的使用方法,当界面中存在多个Text文本视图或者Image图片视图,或者是同时存在不同类型的视图时,我们又该如何去构建一个复杂的页面呢?

ArkUI提供了容器视图的概念,容器视图就像一个"盒子",我们可以将多个元素放在里面,并且规定这些元素的位置,如此就可以实现一个丰富的页面布局。

Column垂直布局容器

ArkUI中提供界面布局容器主要有Column垂直布局容器、Row水平布局容器、Stack堆叠布局容器、Flex弹性布局容器4种常见类型。

首先是Column垂直布局容器,我们在界面中放置2个Text文本视图,并使用Column垂直布局容器使其按照垂直方向排列,如下代码所示:

scss 复制代码
Column(){
  Text('ArkUI极简开发')
    .fontSize(23)
    .fontColor('#333333')
  Text('ArkUI是一套构建分布式应用界面的声明式UI开发框架。')
    .fontSize(17)
    .fontColor('#999999')
}

我们为两个Text文本视图设置不同的字号和颜色,实现常规界面中的显示主副标题的效果。Column垂直布局容器中默认按照居中对齐方式排布内部的元素,我们也可以设置其参数来调整容器内元素的对齐方式,如下代码所示:

scss 复制代码
Column(){
  // 多个视图
}
.alignItems(HorizontalAlign.Start)

上述代码中,我们为Column垂直布局容器添加了alignItems修饰器,设置参数HorizontalAlign水平对齐方向为Start,实现容器内元素左对齐的效果。

是不是想起了前面章节中提及的textAlign修饰器了?是的,alignItems修饰器的对齐方式从左到右也是Start、Center、End。

在预览窗口中我们发现元素之间的间距太近了,我们可以直接设置Column垂直布局容器内部的space参数类设置容器内元素之间的间距,如下代码所示:

scss 复制代码
Column({space:20}){
  // 多个视图
}

最后,如果我们仍然希望整个Column垂直布局容器在界面中居中显示,我们可以使用justifyContent修饰器来调整容器的位置,如下代码所示:

less 复制代码
Column({space:20}){
  // 多个视图
}
.height('100%')
.justifyContent(FlexAlign.Center)
.padding(20)

上述代码中,我们首先使用了height修饰器设置容器的高度覆盖整个屏幕,然后通过设置justifyContent修饰器,使得该容器的在垂直方向的对齐方式为Center居中对齐。最后为了让元素距离屏幕两边留有间距,我们使用padding修饰器来设置四周的间距。

Row水平布局容器

Row水平布局容器的用法与Column垂直布局容器的用法类似,我们可以先导入一张图片到media文件夹中(详情参考上一章节的内容),然后使用Row水平布局容器将排布图片和文字,如下代码所示:

scss 复制代码
Row({ space: 20 }) {
  // 图片
  Image($r('app.media.img_logo'))
    .objectFit(ImageFit.Cover)
    .width(60)
    .height(60)
    .borderRadius(8)

  // 文字
  Text('ArkUI极简开发')
    .fontSize(23)
    .fontColor('#333333')
}

上述代码中,我们设置了Row水平布局容器的space参数值为20,使得内部横向排布的元素之间留有间距。然后在Row水平布局容器的闭包中放置了Image图片视图和Text文本视图,实现多个视图横向排布的效果。

让Row水平布局容器位于页面中间的方式也很类似,设置高度为100%即可,如下代码所示:

less 复制代码
Row({ space: 20 }) {
  // 多个视图
}
.height('100%')
.padding(20)

不错,那如果我们希望两个文本垂直排布,并且最后和图片横向排布又如何实现呢?也很简单,将Row水平布局容器的用法与Column垂直布局容器配合使用,如下代码所示:

scss 复制代码
Row({ space: 10 }) {
  // 图片
  Image($r('app.media.img_logo'))
    .objectFit(ImageFit.Cover)
    .width(60)
    .height(60)
    .borderRadius(8)

  // 文字
  Column({space:5}) {
    Text('ArkUI极简开发')
      .fontSize(17)
      .fontColor('#333333')
    Text('ArkUI是一套构建分布式应用界面的声明式UI开发框架。')
      .fontSize(14)
      .fontColor('#999999')
  }
  .alignItems(HorizontalAlign.Start)
  .width('100%')
}
.height('100%')
.padding({left:10,right:80})

上述代码中,文字部份我们使用了Column垂直布局容器排布了2个文本视图,并设置对齐方式为左对齐,宽度为100%。然后使用Row水平布局容器将文本视图所在的容器与Image图片视图相组合,通过设置高度使其居中对齐,最后使用padding修饰器留出两边的间距。

本章小结

垂直布局和水平布局是UI设计中最为常见的2种布局方式,在分析页面布局时,开发者的首要工作是拆解元素之间的布局,如同案例所示,界面中的3个元素,2个文本视图可以垂直排布组成一个复合视图,再由这个复合视图与图片视图相排布。

编程技术固然重要,但良好的编程设计思路,能让人在开发过程中效率更高。

因此,多想多做,先想后做,才能更好地掌握ArkUI的精髓。

相关推荐
qq_177767371 小时前
React Native鸿蒙跨平台数据使用监控应用技术,通过setInterval每5秒更新一次数据使用情况和套餐使用情况,模拟了真实应用中的数据监控场景
开发语言·前端·javascript·react native·react.js·ecmascript·harmonyos
烬头88211 小时前
React Native鸿蒙跨平台应用实现了onCategoryPress等核心函数,用于处理用户交互和状态更新,通过计算已支出和剩余预算
前端·javascript·react native·react.js·ecmascript·交互·harmonyos
小雨青年2 小时前
鸿蒙 HarmonyOS 6 | 系统能力 (06) 构建现代化通知体系 从基础消息到实况
华为·harmonyos
木斯佳3 小时前
HarmonyOS 6实战(源码解析篇):音乐播放器的音频焦点管理(上)——AudioSession与打断机制
华为·音视频·harmonyos
2601_949593654 小时前
基础入门 React Native 鸿蒙跨平台开发:卡片组件
react native·react.js·harmonyos
qq_177767375 小时前
React Native鸿蒙跨平台剧集管理应用实现,包含主应用组件、剧集列表、分类筛选、搜索排序等功能模块
javascript·react native·react.js·交互·harmonyos
qq_177767375 小时前
React Native鸿蒙跨平台自定义复选框组件,通过样式数组实现选中/未选中状态的样式切换,使用链式调用替代样式数组,实现状态驱动的样式变化
javascript·react native·react.js·架构·ecmascript·harmonyos·媒体
烬头88216 小时前
React Native鸿蒙跨平台采用了函数式组件的形式,通过 props 接收分类数据,使用 TouchableOpacity实现了点击交互效果
javascript·react native·react.js·ecmascript·交互·harmonyos
qq_177767376 小时前
React Native鸿蒙跨平台通过Animated.Value.interpolate实现滚动距离到动画属性的映射
javascript·react native·react.js·harmonyos
qq_177767377 小时前
React Native鸿蒙跨平台实现消息列表用于存储所有消息数据,筛选状态用于控制消息筛选结果
javascript·react native·react.js·ecmascript·harmonyos