HarmonyOS中List组件是否支持局部刷新

HarmonyOS中List组件是否支持局部刷新

HarmonyOS
2024-08-09 12:15:20
浏览
收藏 0
回答 1
待解决
回答 1
按赞同
/
按时间
FengTianYa

可以使用@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 = ''; 
}
分享
微博
QQ
微信
回复
2024-08-09 17:49:46
相关问题
HarmonyOS list局部刷新的问题
934浏览 • 1回复 待解决
List局部刷新,有人知道怎么处理吗?
2249浏览 • 1回复 待解决
HarmonyOS ForEach局部刷新
1626浏览 • 1回复 待解决
list组件是否支持内部移动
1277浏览 • 1回复 待解决
HarmonyOS LIst组件UI不刷新
820浏览 • 1回复 待解决
HarmonyOS List组件动态刷新数据问题
2299浏览 • 1回复 待解决
HarmonyOS List组件指定item刷新实现方案
1238浏览 • 1回复 待解决
HarmonyOS UI是否支持固定行列的组件
590浏览 • 1回复 待解决
HarmonyOS List怎么刷新数据?
1246浏览 • 1回复 待解决