美文网首页ArkTS/ArkUI实战零基础学鸿蒙编程1024
47、鸿蒙/页面和自定义组件生命周期

47、鸿蒙/页面和自定义组件生命周期

作者: 圆梦人生 | 来源:发表于2024-08-08 10:54 被阅读0次

    在开始之前,我们先明确自定义组件和页面的关系:

    • 自定义组件:@Component装饰的UI单元,可以组合多个系统组件实现UI的复用,可以调用组件的生命周期。
    • 页面:即应用的UI页面。可以由一个或者多个自定义组件组成,@Entry装饰的自定义组件为页面的入口组件,即页面的根节点,一个页面有且仅能有一个@Entry。只有被@Entry装饰的组件才可以调用页面的生命周期。

    页面生命周期,即被@Entry装饰的组件生命周期,提供以下生命周期接口:

    • onPageShow:页面每次显示时触发一次,包括路由过程、应用进入前台等场景。
    • onPageHide:页面每次隐藏时触发一次,包括路由过程、应用进入后台等场景。
    • onBackPress:当用户点击返回按钮时触发。

    组件生命周期,即一般用@Component装饰的自定义组件的生命周期,提供以下生命周期接口:

    • aboutToAppear:组件即将出现时回调该接口,具体时机为在创建自定义组件的新实例后,在执行其build()函数之前执行。
    • onDidBuild:组件build()函数执行完成之后回调该接口,不建议在onDidBuild函数中更改状态变量、使用animateTo等功能,这可能会导致不稳定的UI表现。
    • aboutToDisappear:aboutToDisappear函数在自定义组件析构销毁之前执行。不允许在aboutToDisappear函数中改变状态变量,特别是@Link变量的修改可能会导致应用程序行为不稳定。

    生命周期流程如下图所示,下图展示的是被@Entry装饰的组件(页面)生命周期。

    生命周期.png

    相关文章

      网友评论

        本文标题:47、鸿蒙/页面和自定义组件生命周期

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