引用iScroll.js实现上拉和下拖刷新
使用技巧
1、引用iScroll.js, 在初始化时添加两个事件监听:touchMove、DOMContentLoaded。
2、实现iScroll插件的onScrollEnd事件, 也就是在这个事件里调用你自己的ajax方法实现数据的刷新和追加。
3、上拉加载更多请求后台时就相当于分页请求数据,这时候需要在ajax请求时发送pageIndex参数,而初始化加载时需要从后台返回一个pageCount以便前台判断。
4、最关键的就是实现下拉刷新方法(pullDownAction)和上拉加载更多(pullUpAction)方法。
效果图
实现方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
|
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 ); |
引用iScroll.js实现上拉和下拖刷新的更多相关文章
- iscroll.js实现上拉刷新,下拉加载更多,应用技巧项目实战
上拉刷新,下拉加载更多...仿原生的效果----iscroll是一款做滚动效果的插件,具体介绍我就不废话,看官方文档,我只写下我项目开发的一些用到的用法: (如果不好使,调试你的css,想必是个很蛋疼 ...
- 使用iScroll实现上拉或者下拉刷新
上拉或者下拉刷新的需求在移动端是非常常见的需求,大部分情况下,实现这个效果都使用网上现有的解决方案,例如有人使用swiper这个插件, 也有人使用iScroll这个滚动插件.本文的示例是利用iscro ...
- html5+css3实现上拉和下拉刷新
<!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content=& ...
- 微信小程序实现上拉和下拉加载更多
在上一篇文章中,我们知道了使用 scroll-view 可以实现上拉加载更多,但是由于 scroll-view 的限制,它无法实现下拉加载更多,这篇文章我们使用 view 组件来实现 上拉和下拉加载更 ...
- Arduino 极速入门系列 - 光控灯(2) - 关于开关,上拉、下拉电阻那些事
接上篇,这次继续讲解光控灯的另外两个组成部分 - 开关和光敏电阻,光控灯里面将会有自锁开关按钮和光敏电阻.这此主要给新玩电子的朋友解释一下开关按钮的做法. 开关按钮的引脚电平读取问题 - 新手专用 我 ...
- 原生js实现上拉加载
原生js实现上拉加载其实超级简单,把原理整明白了你也会,再也不用去引一个mescroll啦~ 好了,废话不多说,开始进入正题:上拉加载是怎么去做的,原理就是监听滚动条滑到页面底部,然后就去做一次请求数 ...
- iscroll5 上拉,下拉 加载数据
我这里的思路是上拉时候只是加载第一页的内容,可根据实际情况修改其中的代码.请勿照搬.样式没怎么调,可以加载gif动画.1.没有数据时候,下拉可以加载数据.2.没有数据时候,点击也可以加载数据.3.其余 ...
- iscroll5 版本下的 上拉,下拉 加载数据
上拉时候只是加载第一页的内容,可根据实际情况修改其中的代码. <section id="downwraper" class="nodeBottom bot0 bgf ...
- 原生JS实现上拉下拉列表
话不多说,代码上来,有些知识点直接就在注释里 HTML <div class="list-down"> <button id="btn"> ...
随机推荐
- websocket 实现聊天功能
<html> <head> <base href="<%=basePath%>"> <title>webscoket t ...
- Java 异常java.lang.IllegalArgumentException: Illegal group reference
当字符串方法replaceAll()中替换字符含有特殊字符$如, String test = "<StreamingNo>abc</StreamingNo>" ...
- 手动安装配置mongodb
2.1查看当前操作系统版本 2.2下载mongodb安装包 我的下载路径:http://www.mongodb.org/downloads 注意这里要下载和操作系统匹配的版本,因为我的系统是32位的, ...
- Java底层实现 - CPU术语
1.内存屏障(memory barriers)是一组处理器指令,用于实现对内存操作的顺序限制 2.缓冲行(cache line)CPU高速缓存中可以分配的最小存储单位.处理器填写缓存行时 会加载整个缓 ...
- Proguard参数
参数:?-include?{filename}?从给定的文件中读取配置参数?-basedirectory?{directoryname}?指定基础目录为以后相对的档案名称?-injars?{class ...
- 好看的IDE配色方案让代码看起来不再那么凶猛了
写这篇小文的初衷是,笔者是原教旨主义者,一直坚持用IDE默认的配色方案.另外也觉得网上黑色系的配色方案太过bling bling了.但今天尝试用新的配色方案后,兴奋地发现对代码的好感度大幅提升. 嗯, ...
- 原来 laravel 路由 参数可以为可选。。。 很灵活
基本路由 您的应用程序的绝大多数路由将在 app/routes.php 文件中定义.Laravel 中最简单的路由由一个 URI 和一个闭包调用组成. 基本 GET 路由 复制代码代码如下: Rout ...
- iOS WKWebView的javascript alert 不弹的解决方案
- (void)webView:(WKWebView *)webView runJavaScriptAlertPanelWithMessage:(NSString *)message initiate ...
- Codevs 3728 联合权值
问题描述 无向连通图G有n个点,n-1条边.点从1到n依次编号,编号为i的点的权值为Wi ,每 条边的长度均为1.图上两点(u,v)的距离定义为u点到v点的最短距离.对于图G上的点 对(u,v),若它 ...
- objective-c static变量的使用总结
在java中,我们经常使用的是单例模式,这些设计模式在ios开发中也比较常用,最近也在考虑使用在ios开发中使用单例模式 在objective-c中,需要在.m文件里面定义个static变量来表示全局 ...