当前位置:首页 > 日记 > 正文

H5基于iScroll实现下拉刷新和上拉加载更多

H5基于iScroll实现下拉刷新和上拉加载更多

前言

      前一段有个手机端的项目需要用到下拉刷新和上拉加载更多的效果,脑海里第一反映就是微博那种效果,刚开始的理解有些偏差,以为下拉也是追加数据,上拉也是追加数据,后请教同事后发现其实下拉只是刷新最新数据而已,上拉是追加数据。

使用技巧

      1、引用iScroll.js, 在初始化时添加两个事件监听:touchMove、DOMContentLoaded。

      2、实现iScroll插件的onScrollEnd事件, 也就是在这个事件里调用你自己的ajax方法实现数据的刷新和追加。

      3、上拉加载更多请求后台时就相当于分页请求数据,这时候需要在ajax请求时发送pageIndex参数,而初始化加载时需要从后台返回一个pageCount以便前台判断。

      4、最关键的就是实现下拉刷新方法(pullDownAction)和上拉加载更多(pullUpAction)方法。

效果图

 

实现方法

var   myScroll,  pullDownEl, pullDownOffset,  pullUpEl, pullUpOffset,  generatedCount = 0; /** * 下拉刷新 (自定义实现此方法) * myScroll.refresh(); 数据加载完成后,调用界面更新方法 */function pullDownAction () {  setTimeout(function () {      var el, li, i;    el = document.getElementById('thelist');     for (i=0; i<3; i++) {      li = document.createElement('li');      li.innerText = 'Generated row ' + (++generatedCount);      el.insertBefore(li, el.childNodes[0]);    }         myScroll.refresh();   //数据加载完成后,调用界面更新方法   }, 1000); } /** * 滚动翻页 (自定义实现此方法) * myScroll.refresh();   // 数据加载完成后,调用界面更新方法 */function pullUpAction () {  setTimeout(function () {  // <-- Simulate network congestion, remove setTimeout from production!    var el, li, i;    el = document.getElementById('thelist');     for (i=0; i<3; i++) {      li = document.createElement('li');      li.innerText = 'Generated row ' + (++generatedCount);      el.appendChild(li, el.childNodes[0]);    }         myScroll.refresh();   //数据加载完成后,调用界面更新方法  }, 1000); } /** * 初始化iScroll控件 */function loaded() {  pullDownEl = document.getElementById('pullDown');  pullDownOffset = pullDownEl.offsetHeight;  pullUpEl = document.getElementById('pullUp');   pullUpOffset = pullUpEl.offsetHeight;     myScroll = new iScroll('wrapper', {    scrollbarClass: 'myScrollbar',    useTransition: false,    topOffset: pullDownOffset,    onRefresh: function () {      if (pullDownEl.className.match('loading')) {        pullDownEl.className = '';        pullDownEl.querySelector('.pullDownLabel').innerHTML = '下拉刷新...';      } else if (pullUpEl.className.match('loading')) {        pullUpEl.className = '';        pullUpEl.querySelector('.pullUpLabel').innerHTML = '上拉加载更多...';      }    },    onScrollMove: function () {      if (this.y > 5 && !pullDownEl.className.match('flip')) {        pullDownEl.className = 'flip';        pullDownEl.querySelector('.pullDownLabel').innerHTML = '松手开始更新...';        this.minScrollY = 0;      } else if (this.y < 5 && pullDownEl.className.match('flip')) {        pullDownEl.className = '';        pullDownEl.querySelector('.pullDownLabel').innerHTML = '下拉刷新...';        this.minScrollY = -pullDownOffset;      } else if (this.y < (this.maxScrollY - 5) && !pullUpEl.className.match('flip')) {        pullUpEl.className = 'flip';        pullUpEl.querySelector('.pullUpLabel').innerHTML = '松手开始更新...';        this.maxScrollY = this.maxScrollY;      } else if (this.y > (this.maxScrollY + 5) && pullUpEl.className.match('flip')) {        pullUpEl.className = '';        pullUpEl.querySelector('.pullUpLabel').innerHTML = '上拉加载更多...';        this.maxScrollY = pullUpOffset;      }    },    onScrollEnd: function () {      if (pullDownEl.className.match('flip')) {        pullDownEl.className = 'loading';        pullDownEl.querySelector('.pullDownLabel').innerHTML = '加载中...';                pullDownAction();  // ajax call      } else if (pullUpEl.className.match('flip')) {        pullUpEl.className = 'loading';        pullUpEl.querySelector('.pullUpLabel').innerHTML = '加载中...';                pullUpAction(); // ajax call      }    }  });     setTimeout(function () { document.getElementById('wrapper').style.left = '0'; }, 800);} //初始化绑定iScroll控件document.addEventListener('touchmove', function (e) { e.preventDefault(); }, false);document.addEventListener('DOMContentLoaded', loaded, false);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

相关文章

使用store来优化React组件的方法

使用store来优化React组件的方法

组件,方法,优化,电脑软件,store,?在使用 React 编写组件的时候,我们常常会碰到两个不同的组件之间需要共享状态情况,而通常的做法就是提升状态到父组件。但是这样做会有一个问题,就是尽管只有两个组件需要这个状态,但是因为把状态提到了父组件,…

总结PHP中数值计算的注意事项

总结PHP中数值计算的注意事项

数值计算,注意事项,电脑软件,PHP,一:四舍五入1.round — 对浮点数进行四舍五入float round ( float $val [, int $precision ] )2:floor — 舍去法取整(向下取整)float floor ( float $value )3.ceil — 进一法取整(向上取整)float ceil ( fl…

word2010中如何制作目录word2010制

word2010中如何制作目录word2010制

步骤,方法,目录,电脑软件,strong,  大家写文章有时需要写目录,而这又是很繁琐的,尤其是对于写论文,目录必须要有,那么下面就由小编给大家分享下word2010制作目录的技巧,希望能帮助到您。word2010制作目录的步骤步骤一:word2010制作目录的步骤图…

基于原生js运动方式关键点的总结 |

基于原生js运动方式关键点的总结 |

运动,推荐,原生,关键,方式,主要方法:定时器的运用 setInterval(funnction(){},30);为了避免最后时刻速度即将停止时的误差,可以采用下面的方法:if(iSpeed<1)//速度足够小的时候,让速度直接为0,避免速度的波动{iSpeed = 0;}绝对值的运用(主要运用于…

如何在excel中使用小函数

如何在excel中使用小函数

函数,如何在,电脑软件,excel,当你在Excel表上工作时,你需要找到一组数据的最小值,老师也不例外。他们经常需要数最差的分数。接下来,小编将与您分享在Excel中使用小功能的技巧。我希望你能学习并应用它们。 excel中小函数的使用 每个人都必…

ps怎么给照片加一层黑色图层?

ps怎么给照片加一层黑色图层?

图层,照片,黑色,电脑软件,ps,在生活和工作中,经常会把图片换一种风格,搭配不同场景,下面就来给大家介绍一种常见的照片风格制作,如图,在照片上加上一层黑色半透明的图层。软件名称:Adobe Photoshop 8.0 中文完整绿色破解版软件大小:150.1MB更新时…

ps图层蒙版快速制作彩色烟雾字效教

ps图层蒙版快速制作彩色烟雾字效教

教程,图层,烟雾,彩色,快速,效果图:主要过程:教程结束,以上就是ps图层蒙版快速制作彩色烟雾字效教程的全部内容,希望大家喜欢!相关教程推荐:PS打造帅气的中国风水墨烟雾文字特效photoshop 烟雾素材制作简单的烟雾字photoshop 利用烟雾笔刷制作逼真…

怎么让PSD文件与ps程序链接并恢复

怎么让PSD文件与ps程序链接并恢复

恢复,链接,文件,图标,程序,PHOTOSHOP是现在最好用的图像处理软件,PS的文档即PSD文件的图标很漂亮,但有一天你突然发现你的PSD文件的图标不见了,也无法用PHOTOSHOP程序打开了,那说明PSD文件与PS的程序链接出现了问题,这时我们就要把它们重新链接…

Photoshop怎么绘制梦幻的星云?

Photoshop怎么绘制梦幻的星云?

绘制,星云,梦幻,电脑软件,Photoshop,今天和大家聊聊使用Photoshop制作星云图片的技巧。一般来说制作星云效果分为四个部分:星星的制作、星空深蓝效果、光晕和星云制作效果。这四个部分是构成星云图片的主要因素,制作出来的图片是很逼真。下面…

ai打造山谷式第五周年纪念海报教程

ai打造山谷式第五周年纪念海报教程

教程,周年纪念,山谷,海报,电脑软件,这座纪念碑谷的风格是由多种单色,彩色大,和简单的图形,这是既简单又好看,设计师很受欢迎。接下来,萧边教你如何使用Illustrator制作纪念碑谷风格第五周年庆典海报。这个教程简单而粗糙。它主要是关于周年纪念…

PHP编程中的Session阻塞问题与解决

PHP编程中的Session阻塞问题与解决

解决方法,编程,电脑软件,PHP,Session,本文实例讲述了PHP编程中的Session阻塞问题与解决方法。分享给大家供大家参考,具体如下:使用session过程中,在开启session后,同一浏览器,执行同一程序,不同页面会被锁。不同浏览器不会出现这种情况。疑问:是不…

PHP中substr_count | 函数获取子字

PHP中substr_count | 函数获取子字

函数,方法,子字符串,次数,电脑软件,本文实例讲述了PHP中substr_count()函数获取子字符串出现次数的方法。分享给大家供大家参考,具体如下:PHP中的substr_count()可用于计算指定字符串中子字符串出现的次数。substr_count()函数定义如下:substr…