Ionic2实现: 下拉刷新和上拉加载

下拉刷新:

复制代码
 1 <ion-content>
 2   <ion-refresher (ionRefresh)="doRefresh($event)">
 3     <ion-refresher-content
 4       pullingIcon="arrow-dropdown"
 5       pullingText="Pull to refresh"
 6       refreshingSpinner="circles"
 7       refreshingText="Refreshing...">
 8     </ion-refresher-content>
 9   </ion-refresher>
10 </ion-content>
复制代码

TypeScript:

复制代码
 1 @Component({...})
 2 export class NewsFeedPage {
 3   items = [];
 4   doRefresh(refresher) {
 5     console.log('Begin async operation', refresher);
 6 
 7     setTimeout(() => {
 8       this.items = [];
 9       for (var i = 0; i < 30; i++) {
10         this.items.push( this.items.length );
11       }
12       console.log('Async operation has ended');
13       refresher.complete();
14     }, 2000);
15   }
16 
17 }
复制代码

上拉加载:

复制代码
<ion-content>

 <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"
      loadingText="Loading more data...">
    </ion-infinite-scroll-content>
  </ion-infinite-scroll>

</ion-content>
复制代码

TypeScript:

复制代码
@Component({...})
export class NewsFeedPage {
  items = [];

  constructor() {
    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);
  }

}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值