List局部刷新,有人知道怎么处理吗?

List局部刷新

HarmonyOS
2024-06-11 20:38:10
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
NGKSWCIDT

在开发中,使用ForEach去实现列表是一个很常规的操作,那么怎么实现列表的局部刷新呢?通过阅读官方文档中关于ForEach以及状态变量相关的,并没有找见一个通用的demo去实现。

这篇文章的原理在于item的@State和@Observed的使用,父组件和Entry中调用的组件建立双向连接,去实现这个功能,这样就可以实现数据的局部刷新了。

通过List的局部刷新的实现,可以明显的感觉到界面刷新的时候不是整个item在刷新了,而是只有需要刷新的数据才会去刷新;验证的方法就是在相关的ui组件那里打断点,看断点能不能走到断点那里。

List数据局部刷新示例如下:

@Component 
struct Child { 
  @Link items: TestList[]; 
 
  build() { 
    Column() { 
      ForEach(this.items, (item: TestList) => { 
        ChildChild({ item: item }); 
      }) 
      Button(`Button: push`).onClick(() => { 
        this.items[0].index1 = 3; 
        this.items[0].str = 'Third'; 
      }) 
    } 
  } 
} 
 
@Component 
struct ChildChild { 
  @State item: TestList = new TestList(); 
 
  build() { 
    Column() { 
      Text(`${this.item.index1}+'-----'${this.item.str}`) 
    } 
  } 
} 
 
@Entry 
@Component 
struct Parent { 
  @State arr: TestList[] = []; 
  aboutToAppear() { 
    let test1: TestList = new TestList(); 
    test1.index1 = 1; 
    test1.str = 'First'; 
    this.arr.push(test1) 
    let test2: TestList = new TestList(); 
    test2.index1 = 2; 
    test2.str = 'Second'; 
    this.arr.push(test2) 
  } 
 
  build() { 
    Column() { 
      Child({ items: this.arr }) 
      Button(`Button: push`).onClick(() => { 
        this.arr[1].index1 = 4; 
        this.arr[1].str = 'Fourth'; 
      }) 
    } 
  } 
} 
 
@Observed 
class TestList { 
  index1: number = 0; 
  str: string = ''; 
}
分享
微博
QQ
微信
回复
2024-06-12 17:36:56
相关问题
SnapShot定位,有人知道怎么处理
992浏览 • 1回复 待解决
HarmonyOS中List组件是否支持局部刷新
618浏览 • 1回复 待解决
List组件性能问题,有人知道
2075浏览 • 1回复 待解决
有人知道社区怎么预约直播
2920浏览 • 1回复 已解决
如何对网络图片处理有人知道
367浏览 • 1回复 待解决
怎么主动关闭键盘,有人知道
444浏览 • 1回复 待解决
HarmonyOS ForEach局部刷新
497浏览 • 1回复 待解决
有人知道怎么在markdown里面写目录
2408浏览 • 1回复 已解决
怎么压缩一个目录?有人知道
754浏览 • 1回复 待解决
有人知道轻量系统上怎么使用MQTT
2437浏览 • 2回复 已解决
有人知道关于页demo
774浏览 • 1回复 待解决
导包报错,有人知道原因
1164浏览 • 1回复 待解决
有人知道发布页demo
844浏览 • 1回复 待解决
clientid相关问题,有人知道
1852浏览 • 1回复 待解决
如何实现振动,有人知道
1178浏览 • 2回复 待解决
如何获取windowStage,有人知道
476浏览 • 1回复 待解决