如何监听组件再次显示的事件?

上海张律师
• 阅读 2

​##HarmonyOS 应用开发##

我们知道,对于组件的生命周期,有aboutToAppear和aboutToDisAppear,即监听这个组件被挂载和卸载的事件,和被@Entry修饰的页面不同,组件是没有每次显示都能触发的onPageShow这个生命周期的,但是实际上,自定义组件也会有这方面的需求。

我们来看一下这样的场景:

项目的主页面Index.ets,使用Tabs来加载4个子组件(即4个子页面,为了方便理解就统一讲子组件了),有一个叫Page1.ets的子组件,我希望在每次点开的时候(即通过tab切换到这个页面的时候),都能执行一遍一个上下跳动的动画效果。

那么对于子组件的显示,是通过tab的切换实现的,而且是当你切换到某个子组件的时候,这个子组件才会被挂载,但是当你切换到别的子组件时,之前被挂载的子组件并不会被卸载,所以,当你切换回来(类似于onPageShow)的时候,对应的aboutToAppear并不会被再执行一遍。也就是如果我把执行动画效果的代码放在aboutToAppear中的话,这个效果也只会被执行一遍,无法实现我所期望的每次显示都执行一遍的效果。

当然,从挂载卸载的角度触发,也有别的方法,比如用IF来作条件渲染,即监听Tabs的onChange事件,然后通过IF判断这个index,来显示子组件,效果是能实现的,但是会有一个很明显的闪烁,当然这可能是预览器的问题……不过这个方案终究还是不可取的,因为你还要考虑到,子组件里不光是动画,还会有数据加载页面渲染等等一堆事情,你不可能每次切换过来都把这些事情执行一遍的。

最后我在文档里发现了这么一个东西:onVisibleAreaChange,官方的介绍是:组件可见区域变化事件是组件在屏幕中的显示区域面积变化时触发的事件,提供了判断组件是否完全或部分显示在屏幕中的能力,适用于广告曝光埋点之类的场景。看完文档,简化的理解就是:这个子组件显示和被隐藏的时候触发对应的代码。

实现的代码如下:


.onVisibleAreaChange([0.0, 1.0], (isExpanding: boolean, currentRatio: number) => {
      if (isExpanding && currentRatio >= 1.0) {
        this._Donghua();
      }

      if (!isExpanding && currentRatio <= 0.0) {
        this.y =[20,20,20];
      }
    })

点赞
收藏
评论区
推荐文章
Stella981 Stella981
3年前
Flutter 中的组件绘制完成监听、组件生命周期和APP生命周期
Flutter的生命周期说到Flutter的生命周期,其实就是说StatefulWidget的生命周期,因为StatelessWidget是静态控件。StatefulWidget,通过借助于State对象,处理状态变化,并体现在UI上。这些阶段,就涵盖了一个组件从加载到卸载的全过程,即生命周期。
Easter79 Easter79
3年前
Swing自定义事件
1.Swing自定义事件将一个组件的事件传递给另一个组件.使用EventListenerList来管理事件,当A组件触发事件的时候,调用方法fireActionPerformed()来触发事件,然后再B组件中actionPerformed()方法来接收事件.当在容器KeyTextComponent中按下鼠标,我们就可以在Jframe中捕获触发的事
Wesley13 Wesley13
3年前
(持续更新)Java8.0 Lambda表达式实际应用案例
1.桌面开发或者安卓开发组件的监听事件一般都是匿名内部类实现的,代码比较繁琐,看起来也不美观,Java8.0Lambda表达式完美的解决这个问题下面的这个图片中的代码是javafx中lable标签的鼠标点击监听事件的逻辑代码,使用了匿名内部类:!(https://oscimg.oschina.net/oscnet/3c94269889d
Stella981 Stella981
3年前
Android应用如何监听自己是否被卸载
Android应用如何监听自己被卸载呢,Android系统没有提供这个回调方法。想想感觉是不可能监听到的,自己的代码都被卸载掉了,怎么来执行操作来监听呢。后来看到360这个流氓大哥,还真实现了,还挺稳定的。于是,在网上各种搜索。网上还是有很多人讨论,说怎么怎么着,来弄。我也是研究了很久。网上的方案总结说来有1.广播,只能监听到别人卸载。自己被
布局王 布局王
13小时前
鸿蒙仓颉语言开发教程:页面和组件的生命周期
大家下午好,今天要分享的内容是仓颉开发语言中的生命周期。其实幽蓝君比较喜欢分享代码,不太喜欢讲太理论的东西,今天之所以单独写一篇文章分享生命周期的内容,因为这部分内容如果不讲一下还真是容易踩坑。生命周期指的是页面或者组件从加载、显示到消失的过程,在这个过程
上海张律师 上海张律师
7小时前
关于生命周期中的aboutToAppear和onPageShow的理解和应用
​HarmonyOS应用开发在官网的“自定义组件的生命周期”这一章节当中介绍的生命周期中,有两个对开发我觉得很重要的生命周期,分别是aboutToAppear和onPageShow。首先来看一下这两个生命周期的官方文档说明:aboutToAppear:ab
GeorgeGcs GeorgeGcs
3小时前
【HarmonyOS 5】鸿蒙页面和组件生命周期函数
鸿蒙开发能力HarmonyOSSDK应用服务鸿蒙金融类应用(金融理财一、生命周期阶段:创建阶段build:构建组件的UI结构和样式。onDidBuild:build方法执行完毕后调用,可用于数据初始化或额外的UI调整。挂载阶段onPageShow:页面显示
达里尔 达里尔
8个月前
vue3 组件切换监听不到onMounted
用vue3的时候有时候会遇到需要监听组件vif,如果遇到组件切换的时候onMounted钩子函数不触发,那么就用onUpdated这个钩子函数vueonUpdated(()//如果需要一个方法在每次vif切换组件的时候需要每次都触发,但是写在onMount
提升前端开发效率的五种实用技术
组件化开发是一种将页面拆分成独立的可重用组件的开发方式。通过组件化开发,我们能够将复杂的界面逻辑拆分成独立的模块,提高代码的复用性和维护性。常用的组件化框架如React、Vue和Angular,它们提供了强大的组件化开发能力,使我们能够轻松构建复杂的用户界面,并提供了组件的生命周期管理和状态管理机制。
融云IM即时通讯 融云IM即时通讯
6个月前
融云IM干货丨uni-app 生命周期有哪些?
uniapp的生命周期分为应用生命周期、页面生命周期和组件生命周期三类:应用生命周期应用生命周期函数需要在App.vue中声明,主要包含以下函数:onLaunch:当uniapp初始化完成时触发(全局只触发一次)。onShow:当uniapp启动,或从后台