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
相关问题
List局部刷新,有人知道怎么处理吗?
1280浏览 • 1回复 待解决
HarmonyOS ForEach局部刷新
491浏览 • 1回复 待解决
list组件是否支持内部移动
330浏览 • 1回复 待解决
HarmonyOS List组件动态刷新数据问题
997浏览 • 1回复 待解决
HarmonyOS List item 刷新问题
799浏览 • 1回复 待解决
HarmonyOS是否支持图表组件
270浏览 • 1回复 待解决
HarmonyOS web组件是否支持webrtc?
282浏览 • 1回复 待解决
HarmonyOS Image组件是否支持缓存?
286浏览 • 1回复 待解决
HarmonyOS ArkWeb组件是否支持深拷贝?
445浏览 • 2回复 待解决