MJRefresh上拉分页时提前加载(保证视频播放列表在划动分页时顺畅播放)

如上图,视频播放列表有20个条目,当从第20条时继续上拉时,直到上拉完成才进行下一页的数据加载,产生了上图的跳动,极为影响用户体验。

解决方式:

翻看源码头文件,找到如下图所示属性

在刷新方法的代码中为该属性设置一个偏移值,当上拉达到偏移值时,便开始加载数据

- (void)addFooterPreloadWithAutomaticallyRefresh:(BOOL)automaticallyRefresh loadMoreBlock:(void(^)(NSInteger pageIndex))loadMoreBlock{   
    __weak typeof(self) weakSelf = self;
    self.loadMoreBlock = loadMoreBlock;
    MJRefreshAutoNormalFooter * footer = [MJRefreshAutoNormalFooter footerWithRefreshingBlock:^{
        weakSelf.pageIndex += 1;
        if (weakSelf.loadMoreBlock) {
            weakSelf.loadMoreBlock(weakSelf.pageIndex);
        }
        [weakSelf endFooterRefresh];
    }];
    
    footer.automaticallyRefresh = automaticallyRefresh;
    // 设置偏移量
    footer.triggerAutomaticallyRefreshPercent = -70;
    footer.onlyRefreshPerDrag = YES;
    
    footer.stateLabel.font = [UIFont systemFontOfSize:13.0];
    footer.stateLabel.textColor = [UIColor colorWithWhite:0.400 alpha:1.000];
    [footer setTitle:@"加载中…" forState:MJRefreshStateRefreshing];
    [footer setTitle:@"这是我的底线啦~" forState:MJRefreshStateNoMoreData];
    
    self.mj_footer = footer;
}

结果展示(分页展示如丝般顺滑):

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值