在 Ionic 4 中调用 complete() 时无限滚动不起作用

The*_*ram 5 angular ionic4

我有来自后端的大量项目列表。ion-infinite-scroll一旦用户到达列表末尾,我就会使用 ionic来延迟加载数据。但是当用户到达列表末尾时出现以下错误。

在此处输入图片说明

这是我的代码

列表.component.html

<ion-content padding>
    <ion-list>
        <ion-item *ngFor="let i of items">{{i}}</ion-item>
    </ion-list>
    <ion-infinite-scroll (ionInfinite)="doInfinite($event)">
        <ion-infinite-scroll-content loadingSpinner="bubbles"></ion-infinite-scroll-content>
    </ion-infinite-scroll>
</ion-content>
Run Code Online (Sandbox Code Playgroud)

列表.component.ts

export class ActionSheetComponent {

  items = [];
  constructor(
    private actionSheetCtrl: ActionSheetController
  ) {
     for (let i = 0; i < 30; i++) {
      this.items.push(this.items.length);
    }
  }

  doInfinite(infiniteScroll) {
    console.log('Begin async operation');

    setTimeout(() => {
      for (let i = 0; i < 30; i++) {
        this.items.push(this.items.length);
      }

      console.log('Async operation has ended');
      infiniteScroll.complete();
    }, 500);
  }


}
Run Code Online (Sandbox Code Playgroud)

The*_*ram 8

从 Ionic4 开始,V4 中发出的事件类型发生了变化。在 Ionic v3 中,我们发出合成的 Angular 事件,但在 V4 中,我们发出了 HTML 事件,这意味着您需要从 event 访问完整的方法target。现在处理这个问题的正确方法是$event.target.methodName()

解决方案 -

 doInfinite(infiniteScroll) {

    setTimeout(() => {
      for (let i = 0; i < 30; i++) {
        this.items.push(this.items.length);
      }

      infiniteScroll.target.complete(); // this is how you need to call in v4
    }, 500);
  }
Run Code Online (Sandbox Code Playgroud)

希望这会帮助每个使用 ionic v4 的人!