iscroll.js的上拉下拉刷新时无法回弹的解决方法

本文介绍如何解决iOS浏览器中使用iscroll.js时遇到的上拉下拉刷新后页面无法回弹的问题,并提供了解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用过iscroll.js的上拉下拉刷新效果的朋友应该都碰到过这个问题:在iOS的浏览器中,上拉或下拉刷新时,当手指划出屏幕后,页面无法弹回。很多人因为解决不了这个问题,干脆就那样不解决了,还有的直接就不用HTML了,使用原生代替HTML页面。
相信很多朋友也有自己的解决办法,只是没写出来,所以网上都搜不到解决方案。在很多QQ群里面也有很多人在问该怎么解决这个问题,所以我写这篇文章记录一下我的解决方案,希望对一些朋友有所帮助。

上拉下拉刷新的主要代码:

myScroll = new iScroll('wrapper', {
 vScrollbar: false,
 useTransition: true,
 topOffset: pullDownOffset,
 onRefresh: function () {
  if (pullDownEl.className.match('loading')) {
   pullDownEl.className = '';
   pullDownEl.querySelector('.pullDownLabel').innerHTML = 'Pull down to refresh...';
  } else if (pullUpEl.className.match('loading')) {
   pullUpEl.className = '';
   pullUpEl.querySelector('.pullUpLabel').innerHTML = 'Pull up to load more...';
  }
 },
 onScrollMove: function () {
  if (this.y > 5 && !pullDownEl.className.match('flip')) {
   pullDownEl.className = 'flip';
   pullDownEl.querySelector('.pullDownLabel').innerHTML = 'Release to refresh...';
   this.minScrollY = 0;
  } else if (this.y < 5 && pullDownEl.className.match('flip')) {
   pullDownEl.className = '';
   pullDownEl.querySelector('.pullDownLabel').innerHTML = 'Pull down to refresh...';
   this.minScrollY = -pullDownOffset;
  } else if (this.y < (this.maxScrollY - 5) && !pullUpEl.className.match('flip')) {
   pullUpEl.className = 'flip';
   pullUpEl.querySelector('.pullUpLabel').innerHTML = 'Release to refresh...';
   this.maxScrollY = this.maxScrollY;
  } else if (this.y > (this.maxScrollY + 5) && pullUpEl.className.match('flip')) {
   pullUpEl.className = '';
   pullUpEl.querySelector('.pullUpLabel').innerHTML = 'Pull up to load more...';
   this.maxScrollY = pullUpOffset;
  }
 },
 onScrollEnd: function () {
  if (pullDownEl.className.match('flip')) {
   pullDownEl.className = 'loading';
   pullDownEl.querySelector('.pullDownLabel').innerHTML = 'Loading...';
   pullDownAction();
  } else if (pullUpEl.className.match('flip')) {
   pullUpEl.className = 'loading';
   pullUpEl.querySelector('.pullUpLabel').innerHTML = 'Loading...';
   pullUpAction();
  }
 }
});

下面解释一下这段代码的意思。

this.y是页面已经滚动的垂直距离,this.maxScrollY是最大垂直滚动距离,this.pointY手指当前的垂直坐标。

当this.y < this.maxScrollY,就是已经处于上拉的过程,当(this.y < this.maxScrollY) && (this.pointY < 1)时,处于上拉且手指已经触及屏幕边缘,这时候手动触发this.scrollTo(0, this.maxScrollY, 400),页面就开始回弹。

下拉过程也可以同理分析。

转载地址:http://www.jb51.net/article/79632.htm

【IScroll深入学习】解决IScroll疑难杂症 http://www.cnblogs.com/yexiaochai/p/3764503.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值