【鸿蒙HarmonyOS NEXT】页面和自定义组件生命周期

news2024/9/20 18:32:15

【鸿蒙HarmonyOS NEXT】页面和自定义组件生命周期

  • 一、环境说明
  • 二、页面和自定义组件生命周期
  • 三、示例代码加以说明
  • 四、小结

一、环境说明

  1. DevEco Studio 版本:
    在这里插入图片描述

  2. API版本:以12为主
    在这里插入图片描述

二、页面和自定义组件生命周期

需要明确几个概念:

  1. 页面Page
    即应用的UI页面。可以由一个或者多个自定义组件组成,@Entry装饰的自定义组件为页面的入口组件,即页面的根节点,一个页面有且仅能有一个@Entry。只有被@Entry装饰的组件才可以调用页面的生命周期。
    页面生命周期,即被@Entry装饰的组件生命周期,提供以下生命周期接口:

    • onPageShow:页面每次显示时触发。
    • onPageHide:页面每次隐藏时触发一次。
    • onBackPress:当用户点击返回按钮时触发。
  2. 自定义组件Component
    @Component装饰的UI单元,可以组合多个系统组件实现UI的复用。
    组件生命周期,即一般用@Component装饰的自定义组件的生命周期,提供以下生命周期接口:

    • aboutToAppear:组件即将出现时回调该接口,具体时机为在创建自定义组件的新实例后,在执行其build()函数之前执行。
    • aboutToDisappear:在自定义组件即将析构销毁时执行。
  3. 当被@Entry和@Component装饰器同时装饰的页面的生命周期流程如下图所示
    在这里插入图片描述
    需要注意的是,部分生命周期回调函数仅对@Entry修饰的自定义组件生效,它们分别是:onPageShow、onPageHide、onBackPress。

三、示例代码加以说明

  1. 新建项目取名为pagelifecyc的工程,当工程被创建成功后,默认只有一个Index.ets页面。
  2. 新建一个目录,取名为view。
  3. 在view目录下新建一个ArkTS File,取名为TestComponent,使用@Component装饰器修饰,作为自定义组件,并实现aboutToAppear()和aboutToDisappear()函数,具体代码如下:
    /**
     * 自定义组件,生命周期测试
     */
    @Preview  // 为了在单个自定义组件中查看效果,可以去掉
    @Component
    export struct TestComponent{
      // 定义数据用于List组件
      @State arr: number[] = [0,1,2,4,5,6,7,8,9]
    
      // 生命周期函数测试
      aboutToAppear(): void {
        console.info('--自定义组件被创建时,aboutToAppear函数被调用----')
      }
    
      aboutToDisappear(): void {
        console.info('--自定义组件被销毁时,aboutToDisappear函数被调用----')
      }
    
      /**
       * UI布局部分
       */
      build() {
        Column(){
          List({space: 5}){
            ForEach(this.arr,(item: number)=> {
             ListItem(){
               Text(`项目${item}`)
                 .fontSize(15)
                 .fontWeight(FontWeight.Bold)
                 .width('100%')
                 .height(50)
                 .textAlign(TextAlign.Center)
                 .backgroundColor(0xF1F3F5)
             }
            })
          }
        }
      }
    }
    
  4. 新建一个Page,取名为LifecycTestPage,默认已被@Entry和@Component装饰器装饰了。在该页面中实现引入TestComponent组件作为其子组件进行渲染,并实现onPageShow、onPageHide以及onBackPress函数,具体代码如下:
    /**
     * 用于测试页面生命周期
     */
    import { TestComponent } from '../view/TestComponent';
    
    @Preview   // 为了在单页面中查看效果,可以去掉
    @Entry     // @Entry装饰的组件变成了页面
    @Component
    struct LifecycleTestPage {
      // 生命周期相关函数测试
      // 页面被创建时调用
      aboutToAppear(): void {
        console.info('--LifecycleTestPage页面被创建时,aboutToAppear函数被调用----')
      }
    
      // 页面被销毁时调用
      aboutToDisappear(): void {
        console.info('--LifecycleTestPage页面被销毁时,aboutToDisappear函数被调用----')
      }
    
      // 页面显示时调用
      onPageShow(): void {
        console.info('--LifecycleTestPage页面显示时,onPageShow函数被调用----')
      }
    
      // 页面隐藏时被调用
      onPageHide(): void {
        console.info('--LifecycleTestPage页面隐藏时,onPageHide函数被调用----')
      }
    
      // 返回键被点击时调用
      onBackPress(): boolean | void {
        console.info('--LifecycleTestPage页面返回键被点击时调用,onBackPress函数被调用----')
      }
    
      build() {
        Column() {
          // 引入自定义组件
          TestComponent()
        }
        .height('100%')
        .width('100%')
        .alignItems(HorizontalAlign.Center)
        .justifyContent(FlexAlign.Center)
      }
    }
    
  5. 在Index页面中添加跳转按钮,并引入路由,实现从Index页面跳转到LifecycTestPage页面中,具体代码如下:
    import { router } from '@kit.ArkUI';
    
    @Entry
    @Component
    struct Index {
      @State message: string = '生命周期测试';
      @State btnMsg: string = '跳转';
    
      build() {
        Column() {
          Text(this.message)
            .fontSize(20)
            .width('100%')
            .height(50)
            .textAlign(TextAlign.Center)
            .backgroundColor(0xF1F3F5)
            .margin({bottom: 100})
    
           Button(this.btnMsg)
             .width('80%')
             .height(50)
             .onClick(()=>{
               router.pushUrl({url: 'pages/LifecycleTestPage'})
             })
        }
        .height('100%')
        .width('100%')
        .alignItems(HorizontalAlign.Center)
        .justifyContent(FlexAlign.Start)
      }
    }
    
  6. 保持在Index页面,并点击右侧的预览按钮,进行编译和显示Index页面
    页面效果:
    在这里插入图片描述
    点击跳转按钮,观察页面跳转的时候,控制台打印的日志信息,如下所示:
    在这里插入图片描述
    控制台打印出的日志如下:
    I     --LifecycleTestPage页面被创建时,aboutToAppear函数被调用----
    I     --自定义组件被创建时,aboutToAppear函数被调用----
    I     --LifecycleTestPage页面显示时,onPageShow函数被调用----
    
    点击预览界面手机顶部的退回按钮,观察页面跳转的时候,控制台打印的日志信息,如下所示:
    在这里插入图片描述
    在这里插入图片描述
    控制台打印出的日志如下:
    I     --LifecycleTestPage页面返回键被点击时调用,onBackPress函数被调用----
    I     --LifecycleTestPage页面隐藏时,onPageHide函数被调用----
    I     --LifecycleTestPage页面被销毁时,aboutToDisappear函数被调用----
    I     --自定义组件被销毁时,aboutToDisappear函数被调用----
    

四、小结

通过上述的说明和示例演示,相信大家已经很清楚Page页面和自定义组件的生命周期的区别了。细心的读者朋友可能已经发现在自定义组件中同样也可以编写onPageShow、onPageHide以及onBackPress等函数,感兴趣的读者朋友可以尝试下在自定义组件中编写onPageShow、onPageHide以及onBackPress等函数,看看这些函数是否在自定义组件也能被正常调用呢?欢迎大家的留言,我们在留言区进行讨论。

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

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

相关文章

0to1使用Redis实现“登录验证”次数限制

1 引言 系统为了避免密码遭到暴力破解,通常情况下需要在登录时,限制用户验证账号密码的次数,当达到一定的验证次数后,在一段时间内锁定该账号,不再验证。本章将用几行代码实现该功能,完整代码链接在文章最…

Markdown全兼容,MarkText打造专业文档新体验

前言 在科技的洪流中,我们不仅是见证者,更是创造者。它赋予我们力量,将遥不可及的梦想拉近至指尖,让生活的每一刻都充满无限可能。随着数字化内容的爆炸性增长,Markdown作为一种轻量级标记语言,凭借其简洁…

tekton构建标准ci(clone repo, test, build push img)

场景介绍 我们在上一篇文章中构建了一个最简单的ci,接下来我们对我们的github的项目构建一个较标准的ci。 Tekton简介,安装和构建最简单ci/cd-CSDN博客文章浏览阅读239次,点赞2次,收藏2次。本文介绍了tekton是什么,如…

vsftpd配置用户和密码让其他客户端连接

一、第一个主机:vsftpd下载及配置 前置准备: #卸载防火墙 yum -y remove firewalld #为了不让防火墙有影响,iptables配置也清空 iptables -F vim /etc/selinux/conf SELINUXdisabled #主要是把它改为disabled或者permissive SELINUXTYPEtargeted #重启linux让seli…

[Web安全 网络安全]-安全法规 网络基础 信息收集

文章目录: 一:网络安全法规 二:计算机网络 1.计算机网络的组成 2.网络分层模型(OSI七层 TCP/IP四层) 3.通信协议 IP协议 UDP协议/TCP协议 TCP协议 UDP协议 区别 HTTP协议/HTTPS协议 HTTP协议 HTTPS协议…

RedissonClient 分布式队列工具类

注意:轻量级队列可以使用工具类,重量级数据量 请使用 MQ 本文章基于redis使用redisson客户端实现轻量级队列,以及代码、执行结果演示 一、常见队列了解 普通队列:先进先出(FIFO),只能在一端添…

【网络安全 | 甲方建设】SaaS平台、Jira工具及Jenkins服务器

原创文章,不得转载。 文章目录 SaaS平台友好性Jira友好性Jenkins友好性SaaS平台 SaaS,全称为 “Software as a Service”(软件即服务),是一种基于云计算的软件交付模型。在这种模型中,软件不需要用户在本地安装和维护,而是通过互联网访问和使用。软件通常由服务提供商托…

RLC(电阻、电感、电容)

RLC(电阻、电感、电容) 目录一、两个电阻(R1,R2),电容(C1,C2)的串联/并联公式?二、请画出这个1ms, 1V的Vin脉冲信号在Vout端的大致图像1.电路图2.…

中秋猜灯谜_猜字谜小程序源码,无需服务器

这款小程序搭建是免服务器和域名的,serverless,没有后端; 无需设置合法域名的!上传就可以使用; 只需要使用微信开发者工具打开源码然后上传审核就可以了! 这款小程序其实比较简洁,分两种模式青铜模式(普通)和王者模式(困难),猜…

关于蓝屏查看日志分析原因

一、前提 虽然电脑经常蓝屏,或者发生了蓝屏现象,但是仍然可以进入系统,并且可以进行桌面操作。 二、查看蓝屏日志 1.按下win键,搜索计算机管理。 2.依次点击:系统工具->事件查看器->Windows日志->系统 3.在…

CosyVoice:开源强大的 AI 语音合成工具

在当今科技飞速发展的时代,AI 语音合成技术正逐渐改变着我们的生活。今天,就为大家介绍一款卓越的语音合成工具——CosyVoice。 一、安装步骤 克隆和安装: 克隆仓库:git clone --recursive https://github.com/FunAudioLLM/Cos…

linux使用samba共享目录,其他虚拟机和windows都可以访问

一、192.168.137.12主机作为源目录主机,将/samba/shared_dir目录分享出去 #192.168.137.12主机: rpm -q samba #查看是否安装 yum -y install samba #创建共享目录 mkdir /samba/shared_dir -p #给共享目录赋权 chown -R samba.samba /samba #提示用户不…

【流程设计】JAVA系统集成activiti工作流,流程设计器,在线审批,会签,驳回,流程图查看(实际多套系统运用案例分析)

基于Javavue开发的智能审批系统,低代码平台方案 其他资料,软件资料清单列表部分文档清单:工作安排任务书,可行性分析报告,立项申请审批表,产品需求规格说明书,需求调研计划,用户需求…

图论篇--代码随想录算法训练营第五十二天打卡| 101. 孤岛的总面积,102. 沉没孤岛,103. 水流问题,104.建造最大岛屿

101. 孤岛的总面积 题目链接:101. 孤岛的总面积 题目描述: 给定一个由 1(陆地)和 0(水)组成的矩阵,岛屿指的是由水平或垂直方向上相邻的陆地单元格组成的区域,且完全被水域单元格…

攻防世界 unseping

unseping 攻防世界web新手练习 -unseping_攻防世界web新手题unseping-CSDN博客 这道题对我来说还是有点难&#xff0c;什么oct绕过命令执行第一次遇到捏&#xff0c;所以基本是跟着别人的wp写的&#xff0c;一点点记录吧 先对源码进行分析 <?php highlight_file(__FILE…

LLVM IR指令VM混淆分析

未混淆编译 编写一个最简单的测试代码&#xff0c;对 test_add函数用于对两个数相加&#xff1a; int __attribute((__annotate__("vm"))) test_add(int a, int b) {int c a b;return c; }int main(void) {int c test_add(1, 2);return c; } 编译成中间代码&am…

【佳学基因检测】如何知道一个网站是用Nginx还是Apache运行的服务器。

【佳学基因检测】如何知道一个网站是用Nginx还是Apache运行的服务器。 要确定一个的网站是由Nginx还是Apache服务器运行&#xff0c;可以使用以下几种方法&#xff1a; 1. 查看HTTP头信息 您可以通过检查网站返回的HTTP头信息来判断使用的是哪种服务器。具体步骤如下&#x…

Kafka【十三】消费者消费消息的偏移量

偏移量offset是消费者消费数据的一个非常重要的属性。默认情况下&#xff0c;消费者如果不指定消费主题数据的偏移量&#xff0c;那么消费者启动消费时&#xff0c;无论当前主题之前存储了多少历史数据&#xff0c;消费者只能从连接成功后当前主题最新的数据偏移位置读取&#…

FastAPI+Vue3零基础开发ERP系统项目实战课 20240906 上课笔记 fastapi的各种练习

回顾练习 用FastAPI写一个接口&#xff0c;这个接口能够返回九九乘法表的字符串。 获取九九乘法表&#xff1a; for i in range(1, 10):for j in range(1, i 1):print(f"{j} x {i} {j * i}", end"\t")print()# 得到字符串 talbe99 "" for …

多环境jdk安装,CentOS,统信UOS,Ubuntu,KylinOS,windows

文章目录 1.CentOS1.1yum安装1.2压缩包安装 本文档只是为了留档方便以后工作运维&#xff0c;或者给同事分享文档内容比较简陋命令也不是特别全&#xff0c;不适合小白观看&#xff0c;如有不懂可以私信&#xff0c;上班期间都是在得 1.CentOS 1.1yum安装 yum install -y jav…