第四篇 - 层叠布局、自定义组件、ForEach循环生成组件

导读:在本篇文章里,您将掌握层叠布局、自定义组件的用法,特别是自定义组件将来的开发中必然会用,其中应该特别关注自定义组件的一些规范与装饰器。

Stack - 层叠容器组件

  • 在App效果中,我们经常看到一些阴影蒙版加载中遮罩等,如下图列表所示:

  • 像这种:把某个组件堆叠到另外一个组件上的效果,称之为层叠效果或者堆叠效果(就像小时候玩的叠罗汉,一个人叠在另一个人上面)

    • 温馨提示:成都网友请勿看上图
  • 使用语法

    Stack() {
    item1()
    item2()
    item3()
    }
  • 默认情况下:越在后面的组件越叠在最高层(就像叠罗汉,后来的在最上),所以上述代码后的层级效果如下图

  • 默认情况下:子组件都在Stack容器内居中堆叠,如果需要修改,需要通过alignContent参数实现位置的相对移动,一共有9种方式如下图

  • 修改方法

        Stack({ alignContent: Alignment.TopStart }) { // 改成在左上对齐堆叠
    .....
    }
  • 如果需要手动指定谁在最上层,可以使用zIndex属性,修改层级。zIndex的值越大越叠在最上面

    Stack({ alignContent: Alignment.BottomStart }) {
    Column() {
    Text('Stack子元素1').fontSize(20)
    }.width(100).height(100).backgroundColor(0xffd306).zIndex(2) Column() {
    Text('Stack子元素2').fontSize(20)
    }.width(150).height(150).backgroundColor(Color.Pink).zIndex(1) Column() {
    Text('Stack子元素3').fontSize(20)
    }.width(200).height(200).backgroundColor(Color.Grey) }.width(350).height(350).backgroundColor(0xe0e0e0)
    • 此时,虽然子元素1是一开始写的,但是它的zIndex最大,所以会在最上层。子元素2的zIndex值小一点,所以在中间。子元素3因为没有写zIndex,层级最低,所以在最里层。效果如下图

自定义组件

为什么需要
  • 很多时候我们需要自定义一些由其他组件布局组合在一起的组件,方便在界面上复用,例如上期布置的附加作业年度待办目标

  • 待办列表区里的每一项组成元素比较多,比如有Row、Checkbox、Text等。而且这些元素组合起来的部分,多次需要使用。那么为了更好的维护、修改、复用,可以把这一部分封装成自定义组件

组件怎么创建
  • 一般情况下,为了更好的管理项目中的文件,我们会把自定义组件放到一个跟pages目录同级的新的文件夹里,起名叫components或者view。文件夹起名每个人都有自己的喜好,这里我不强求。但是本文后面以view起名作为存放组件的文件夹

    • 华为鸿蒙官网的Codelabs上大部分示例代码都是以view作为文件夹,所以这里猫林老师也保持同步

  • 组件将来我们都以.ets文件结尾,接下来,我们在view文件夹里创建一个组件文件:对着view文件夹鼠标右键->新建->ArkTS File->然后输入组件名即可

  • 注意:组件名应该使用多单词大驼峰形式,建好后如下图

  • 那么如何快速生成一个组件结构呢?输入comp出提示后按回车即可

  • 此时本文件会生成如下代码

    @Component
    struct {
    build() { }
    }
  • 注意看会发现,代码中还没有组件名字,因此我们还需要手动填入名字。名字跟文件名应该保持一致,因此改完后如下

    @Component
    struct ToDoItem {
    build() { }
    }
  • 这样就建好一个空组件了

装饰器 - @Component与@Entry
  • 大家通过代码可以发现,无论是新建项目默认生成的Index.ets文件,或者是我们刚刚创建的ToDoItem自定义组件,都有struct关键字。

  • 这里先对它做个说明

    • struct代表结构体,也是一种数据类型(有兴趣详细了解可以去学习TS语法)

    • 但对于我们目前的鸿蒙应用开发中,暂时只要知道。不管是页面还是自定义组件(页面也可以理解为就是个很大的组件),都用struct修饰,即都为以下格式

    • struct 组件名{
      build() { }
      }
    • 每个组件(页面也是组件),内都必须有个build函数,在这个函数里写描述界面的代码

      • 提示:别忘了,每个build里有且只有一个根容器哦
    • 学过TS或者Java或者C的都知道,struct只是一个结构体,怎么就跟组件扯上关系了呢?

    • 这就跟它上面的@Component有关

  • @Component说明

    • 这是一个装饰器

    • 通过上一篇的学习我们了解到装饰器可以让某个数据具备特殊功能,例如@State可以让数据驱动UI更新

    • 所以**@Component这个装饰器就是能让struct这个数据具备组件的功能**

    • 因此你会发现默认生成的Index.ets和我们自定义的组件TOdoItem都有这个装饰器

  • @Entry又是什么呢?

    • 入口的意思
    • 作用:把某个组件作为这个页面的第一个入口组件启动
    • 一个页面有很多自定义组件,那么启动这个页面到底以哪个组件作为入口组件呢?就是通过@Entry来指定的
    • 并且,加了@Entry的组件,也能被预览器预览
预览自定义组件
  • 自定义组件创建完,我们需要一边写代码一边看效果。可是默认情况下自定义组件无法在预览器里进行预览,这时候需要加一个装饰器@Preview

    @Preview
    @Component
    struct ToDoItem {
    build() { }
    }
  • 这样我们就能进行界面编写,并且在预览器看到预览效果了

构建TodoItem自定义组件的界面

  • 根据效果图分析发现这个组件根容器应该是一个Row,里面两个子组件:CheckboxText

  • 且Row需要设置圆角、背景色、最好给个高度,Checkbox需要给左右外间距

  • 代码如下

      build() {
    Row() {
    Checkbox()
    .margin({ left: 20, right: 20 })
    Text('中彩票500万')
    }
    .width('100%')
    .height(40)
    .backgroundColor(Color.White)
    .borderRadius(20)
    }
如何使用自定义组件
  • 需要先导出、再导入,即可使用

  • 导出:

    • 只要在struct前加一个export即可
    export struct ToDoItem {
    ....
    }
  • 导入:

    • import语法
    import { 组件名 } from '路径'
    // 例
    import { ToDoItem } from '../view/ToDoItem'
  • 使用:

    ToDoItem()
    
    
  • DevEco非常强大,我们也可以不写导入的代码,让DevEco自动生成

    • 做法:给组件加完export后,来到需要用到组件的地方,直接写组件名,出提示后按回车

  • 至此,我们完成了TodoItem组件的简单编写。并通过它学习了装饰器、组件创建和使用的相关知识。等接下来完成“年度待办”案例时,还会回来丰富它,但目前就到此为止吧

ForEach循环生成组件

  • 若需要根据数组数据生成一堆同类型的组件,则需要用到ForEach

  • 作用:根据数组生成组件,数组有多少个元素,就生成多少个组件

  • 语法:

    ForEach (数组, (item: 类型, index: number) => {
    // 组件
    })
  • 例:

    @State arr: string[] = ['a', 'b', 'c', 'd']
    
    ForEach (this.arr, (item: string, index: number) => {
    // 组件
    Row () {
    Text(`item的值是:${item},index是:${index}`)
    }
    })
  • 结果如下

注:ForEach有第三个参数,是键值生成函数。作用:为数据源arr的每个数组项生成唯一且持久的键值。有点类似vue里的v-bind:key,这里我就不细讲了,等哪一天专门出一篇技术文讲解。本系列文章主要是侧重于教会开发技能,理论细节及各种原理和性能优化等内容,未来会偶尔写文说明,所以敬请关注本号,免得错过最新内容。

  • 提示:ArkTS是一种强类型语言,所以每种数据必须声明类型,比如(item: string, index: number),不能省略类型
  • 试一试,大家可以用ForEach生成我们刚刚封装的TodoItem看看

总结内容

  • 本篇文章我们主要学习了三个方面:Stack、自定义组件、ForEach
  • Stack:
    • 层叠组件,只要是实现一个组件叠在另外一个组件上面的都可以用Stack包起来
    • 默认越后面写的组件层级越高
    • 可以通过zIndex属性方法修改,数字越大层级越高
  • 自定义组件
    • 当某个界面区域可能要多次复用时,封装成自定义组件方便复用
    • 其次,自定义组件也能更好的管理代码文件、让界面更清爽、利于维护
    • @Component 修饰的结构体才算组件
    • @Entry是入口的意思,代表某个页面启动的第一个组件
    • @Preview可以预览自定义组件
    • 导出组件:export
    • 导入组件:import
  • ForEach
    • 根据数组生成组件

课后练习

  • 判断题

    • 自定义组件可以直接预览
  • 问答题

    • 请说出下列代码的层级

      Stack() {
      组件A().zIndex(2)
      组件B().zIndex(0)
      组件C()
      }
  • 今天又补全了一些知识,大家可以把上一篇文章的年度待办计划作业的布局给完成了,下一期会讲组件传值的相关知识

  • 附:年度待办计划初始数据

      @State totalTasks: Array<TodoModal> = [
    { text: "月入5万", finished: false },
    { text: "中彩票500万", finished: false },
    { text: "找个富婆", finished: false },
    { text: "买套别墅", finished: false },
    { text: "改掉爱做梦的习惯", finished: false },
    ];

    class TodoModal {

    text: string = ''

    finished: boolean = false

    }


互动环节

  • 看到那个赞了吗?给我狠狠点下去!

交流群

  • 建了个鸿蒙交流群,帮助希望从业的人员方便交流技术以及获取鸿蒙认证。需要的请添加猫林老师微信(llybf365),拉你进群

鸿蒙应用开发从入门到入行 - 篇4:层叠布局、自定义组件、ForEach的更多相关文章

  1. Python Web自动化测试入门与实战,从入门到入行

    Python Web自动化测试入门与实战 购买地址 · 京东:https://item.jd.com/69239480564.html   天猫:https://detail.tmall.com/it ...

  2. LARK BOARD开发板入门学习-第2篇

    1. 本次主要研究下HDMI接口,使用芯片是CH7033,这个芯片可以接VGA和HDMI两种接口,和FPGA的接口是地址数据总线 2. 值得注意的地方,下图的D1,双二极管BAT54S在电路中一般用于 ...

  3. 【golang-GUI开发】struct tags系统(二)qt的自定义组件和构造函数

    今天我们来讲讲自定义组件和它的构造函数. 在前面的文章里我们已经接触了好几个自定组件,这次的示例是一个自定义对话框,他有一个about按钮,点击按钮可以显示出Qt的信息或者用户输入的信息.这是效果图: ...

  4. 「Android 开发」入门笔记

    「Android 开发」入门笔记(界面编程篇) ------每日摘要------ DAY-1: 学习笔记: Android应用结构分析 界面编程与视图(View)组件 布局管理器 问题整理: Andr ...

  5. 《ASP.NET Core跨平台开发从入门到实战》Web API自定义格式化protobuf

    <ASP.NET Core跨平台开发从入门到实战>样章节 Web API自定义格式化protobuf. 样章 Protocol Buffers 是一种轻便高效的结构化数据存储格式,可以用于 ...

  6. android开发之自定义组件

    android开发之自定义组件 一:自定义组件: 我认为,自定义组件就是android给我们提供的的一个空白的可以编辑的图片,它帮助我们实现的我们想要的界面,也就是通过自定义组件我们可以把我们要登入的 ...

  7. 浅谈入行Qt桌面端开发程序员-从毕业到上岗(1):当我们说到桌面端开发时,我们在谈论什么?

    谈谈我自己 大家好,我是轩先生,是一个刚入行的Qt桌面端开发程序员.我的本科是双非一本的数学专业,22年毕业,只是部分课程与计算机之间有所交叉,其实在我毕业的时候并没有想过会成为一名程序员,也没有想过 ...

  8. PHP开发入行真功夫 三扬科技

    前言与目录 PHP开发入行真功夫 前言 PHP开发入行真功夫 目录   第2章 基本语法 2.1.1 判断闰年程序 2.1.2 我们现在能做的…… 2.2.1 PHP的语言概貌 2.2.2 为我们的程 ...

  9. 《开发专家 Visual C 开发入行真功夫》笔记

    智能感知的功能,输入 is 后,同时按下Alt + →这两个键就出现了供选择变量.方法.宏等的列表,继续输入 in 后,isInit就出来了. stdafx.h预编译头文件,.h应用程序主头文件,do ...

  10. 最全华为鸿蒙 HarmonyOS 开发资料汇总

    开发 本示例基于 OpenHarmony 下的 JavaScript UI 框架,进行项目目录解读,JS FA.常用和自定义组件.用户交互.JS 动画的实现,通过本示例可以基本了解和学习到 JavaS ...

随机推荐

  1. Linux操作系统和文件系统、常见命令(下)

    C语言的绝大部分内容应该记录在以.c作为拓展名的文件里,这种文件叫做C语言的源文件 C语言程序里还包括以.h作为拓展名的文件,这种文件叫头文件(只有极少数的内容可以记录在头文件里) C语言程序里可以使 ...

  2. Nuxt.js 应用中的 app:redirected 钩子详解

    title: Nuxt.js 应用中的 app:redirected 钩子详解 date: 2024/10/3 updated: 2024/10/3 author: cmdragon excerpt: ...

  3. 【USB3.0协议学习】Topic1·USB3.0Hub的一些机制

    一.USB3.0 Hub的单播(非广播)机制 Hub通过解析下行packet header中的Route String字段识别packet要传递的终点,其中4'b0000代表hub本身,4'b0001 ...

  4. Uefi ABL读取XBL设置的标志位

    PBL(启动固化程序)-> XBL(扩展引导加载程序,负责初始化芯片驱动和核心应用功能.XBL通常会加载一些平台相关的驱动程序,并提供通用接口)-> ABL(应用引导加载程序,负责引导操作 ...

  5. Python:条件分支 if 语句全讲解

    Python:条件分支 if 语句全讲解 如果我拿出下面的代码,阁下该做何应对? if not reset_excuted and (terminated or truncated): ... els ...

  6. docker-compose -- 创建 redis && mysql

    version: '3' services: nest-admin-web: image: buqiyuan/vue3-antdv-admin:stable container_name: nest- ...

  7. 08 ELMo模型(双向LSTM模型解决词向量多义问题)

    博客配套视频链接: https://space.bilibili.com/383551518?spm_id_from=333.1007.0.0 b 站直接看 配套 github 链接:https:// ...

  8. Centos7下Docker搭建Matomo

    1.docker安装和启动 wget https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo -O /etc/yum.repo ...

  9. 使用wxpython开发跨平台桌面应用,实现程序托盘图标和界面最小化及恢复处理

    在前面随笔<基于wxpython的跨平台桌面应用系统开发>介绍了一些关于wxpython开发跨平台桌面应用的总体效果,开发桌面应用,会有很多界面细节需要逐一处理,本篇随笔继续深入该主题,对 ...

  10. Go语言单元测试的执行

    Go 语言推荐测试文件和源代码文件放在同一目录下,测试文件以 _test.go 结尾.比如,当前 package 有 calc.go 一个文件,我们想测试 calc.go 中的 Add 和 Mul 函 ...