HarmonyOS List组件能实现ListItem的局部刷新吗?

List组件能实现ListItem的某一个子组件刷新吗?

在用List组件,使用LazyForeach加载,想单独刷新某一个ListItem的子组件的内容时,整个Item全部都刷新了。

比如ListItem里面有一个Image和Text组件,我现在只改变了这个Item的数据模型的Text的内容,结果Image组件也会刷一下,体验不好。能不能像RecyclerView那样真正做到局部刷新呢?

HarmonyOS
2024-08-30 10:05:40
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
put_get

您可以使用@State和@Observed,

父组件和Entry中调用的组件建立双向连接,去实现这个功能,这样就可以实现数据的局部刷新了,您可以参考以下代码示例:

@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 = ''; 
}

参考常见使用问题 - LazyForEach仅改变文字但是图片闪烁问题

https://developer.huawei.com/consumer/cn/doc/harmonyos-guides-V5/arkts-rendering-control-lazyforeach-V5

分享
微博
QQ
微信
回复
2024-08-30 20:30:27
相关问题
HarmonyOSList组件是否支持局部刷新
615浏览 • 1回复 待解决
List局部刷新,有人知道怎么处理
1280浏览 • 1回复 待解决
HarmonyOS ForEach局部刷新
491浏览 • 1回复 待解决
HarmonyOS如何实现list listitem拖拽
895浏览 • 1回复 待解决
ListListItem组件使用
1747浏览 • 1回复 待解决
HarmonyOS List组件动态刷新数据问题
997浏览 • 1回复 待解决
HarmonyOS List第一个可见ListItem
294浏览 • 1回复 待解决
如何对某个组件实现局部截图?
363浏览 • 1回复 待解决