鸿蒙next开发进阶:合理处理高负载组件的渲染示例

 介绍

本示例是合理处理高负载组件的渲染文章的示例代码,主要讲解如何通过DisplaySync优化高负载组件的渲染,减少丢帧情况的发生。

效果图预览

使用说明

  1. 通过组件复用,加载10年的日历数据,每个复用组件都在aboutToReuse接口中加载一个月的数据。
  2. 通过DisplaySync的帧回调接口,在组件复用时将一个月的数据拆成多份,并在每一帧中加载其中一份数据,减少每一帧绘制的组件数量,减少丢帧现象的发生。

实现思路

普通数据加载,详细代码可参考ReusePage.ets

  1. 计算未来10年的日历数据(包括农历日期),放入数组中待用。

    initCalenderData() {
      hiTraceMeter.startTrace('push_data_direct', 1);
      for (let k = this.currentYear; k < 2035; k++) {
        ...
      }
      hiTraceMeter.finishTrace('push_data_direct', 1);
    }
  2. 通过List组件,在组件复用的aboutToReuse接口中直接加载数据

    ...
    List() {
      LazyForEach(this.contentData, (monthItem: Month) => {
        ListItem() {
          ItemView({
            monthItem: monthItem,
            currentMonth: this.currentMonth,
            currentDay: this.currentDay
          }).reuseId("reuse_id_" + monthItem.days.length.toString())
        }
      })
    }
    ...
    
    @Reusable
    @Component
    struct ItemView {
      ...
      aboutToReuse(params: Record<string, Object>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值