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 ForEach局部刷新
94浏览 • 1回复 待解决
HarmonyOS List组件动态刷新数据问题
81浏览 • 1回复 待解决
HarmonyOS List item 刷新问题
234浏览 • 1回复 待解决
HarmonyOS toggle组件是否支持完全受控
148浏览 • 0回复 待解决
HarmonyOS ArkWeb组件是否支持深拷贝?
143浏览 • 2回复 待解决
HarmonyOS List组件和WaterFlow组件增强
148浏览 • 1回复 待解决
Swiper是否支持组件复用
520浏览 • 1回复 待解决
Text组件是否支持多行显示
1714浏览 • 1回复 待解决