mescroll-下拉刷新上拉加载

快速开始 :(移步官网:mescroll

下载并引用 mescroll.min.css , mescroll.min.js

拷贝以下布局结构 :

1
2
3
<div id="mescroll" class="mescroll"> //id可以改,而"mescroll"的class不能删
//列表内容,如:<ul>列表数据</ul> ...
</div>

创建mescroll对象 :

1
2
3
4
5
6
7
8
9
var mescroll = new MeScroll("mescroll", {
down: {
callback: downCallback
},
up: {
callback: upCallback,
isBounce: false
}
})

处理回调 :

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
//下拉刷新的回调
function downCallback() {
$.ajax({
url: 'xxxxxx',
success: function(data) {
//联网成功的回调,隐藏下拉刷新的状态;
mescroll.endSuccess(); //无参
//设置数据
//setXxxx(data);//自行实现 TODO
},
error: function(data) {
//联网失败的回调,隐藏下拉刷新的状态
mescroll.endErr();
}
});
}
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
//上拉加载的回调 page = {num:1, size:10}; num:当前页 默认从1开始, size:每页数据条数,默认10
function upCallback(page) {
$.ajax({
url: 'xxxxxx?num=' + page.num + "&size=" + page.size, //如何修改page.num从0开始 ?
success: function(curPageData) {
//联网成功的回调,隐藏下拉刷新和上拉加载的状态;
//mescroll会根据传的参数,自动判断列表如果无任何数据,则提示空,显示empty配置的内容;
//列表如果无下一页数据,则提示无更多数据,(注意noMoreSize的配置)

//方法一(推荐): 后台接口有返回列表的总页数 totalPage
//必传参数(当前页的数据个数, 总页数)
//mescroll.endByPage(curPageData.length, totalPage);

//方法二(推荐): 后台接口有返回列表的总数据量 totalSize
//必传参数(当前页的数据个数, 总数据量)
//mescroll.endBySize(curPageData.length, totalSize);

//方法三(推荐): 您有其他方式知道是否有下一页 hasNext
//必传参数(当前页的数据个数, 是否有下一页true/false)
//mescroll.endSuccess(curPageData.length, hasNext);

//方法四 (不推荐),会存在一个小问题:比如列表共有20条数据,每页加载10条,共2页.
//如果只根据当前页的数据个数判断,则需翻到第三页才会知道无更多数据
//如果传了hasNext,则翻到第二页即可显示无更多数据.
//mescroll.endSuccess(curPageData.length);

//设置列表数据
//setListData(curPageData);//自行实现 TODO
},
error: function(e) {
//联网失败的回调,隐藏下拉刷新和上拉加载的状态
mescroll.endErr();
}
});
}

mescroll.m.js

您如果在vue, angular等环境中,因作用域的问题未能正常引入或初始化 Mescroll 对象,则引用 mescroll.m.js; mescroll.m.js 只是去掉了mescroll.min.js 套的一层模块规范的代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
(function(name, definition) {
//检测上下文环境是否为AMD或CMD
var hasDefine = typeof define === 'function',
// 检测上下文环境是否为Node
hasExports = typeof module !== 'function' && module.exports;
if (hasDefine) {
//AMD环境或CMD环境
define(definition);
} else if (hasExports) {
//定义为普通Node模块
module.exports = definition();
} else {
//将模块的执行结果挂在window变量中,在浏览器中this指向window对象
this[name] = definition();
}

})('Mescroll', function() {
var Mescroll = function() {}
return Mescroll
})

mescroll.m.js 因为没有闭包限制作用域,所以能解决某些情况下引用 mescroll.min.js 报 ‘Mescroll’ undefined 的问题

参数说明 :

1
var mescroll = new MeScroll ( "mescroll" , { down : { 下拉刷新的配置参数 } , up : { 上拉加载的配置参数 } } ) ;

down 下拉刷新的配置参数

参数名

默认值

说明

use

true

是否启用下拉刷新 如果配置false,则不会初始化下拉刷新的布局

auto

true

是否在初始化完毕之后自动执行一次下拉刷新的回调 callback

autoShowLoading

false

如果设置auto=true ( 在初始化完毕之后自动执行下拉刷新的回调 ) , 那么是否显示下拉刷新的进度

isLock

false

是否锁定下拉刷新 如果配置true,则会锁定不可下拉,可通过调用mescroll.lockDownScroll(false)解锁

isBoth

false

下拉刷新时,如果滑动到列表底部是否可以同时触发上拉加载

offset

80

在列表顶部,下拉大于80px,松手即可触发下拉刷新的回调

outOffsetRate

0.2

在列表顶部,下拉的距离大于offset时,改变下拉区域高度比例; 值越接近0,高度变化越小,表现为越往下越难拉

bottomOffset

20

当手指touchmove位置在距离body底部20px范围内的时候结束上拉刷新,避免Webview嵌套导致touchend事件不执行 这是1.2.1版本新增的配置,请检查最新版~

minAngle

45

触发下拉最少要偏移的角度(滑动的轨迹与水平线的锐角值),取值区间 [0,90];默认45度,即向下滑动的角度大于45度(方位角为45°145°及225°315°)则触发下拉;而小于45度,将不触发下拉,避免与左右滑动的轮播等组件冲突; 注意:没有必要配置超出[0,90]区间的值,否则角度限制无效; 因为假设配置60, 生效的方位角就已经是60°到120° 和 240°到300°的范围了; 这是1.1.6版本新增的配置,请检查更新最新版~

hardwareClass

“mescroll-hardware”

硬件加速样式,解决iOS下拉因隐藏进度条而闪屏的问题

warpClass

“mescroll-downwarp”

下拉刷新的布局容器样式

resetClass

“mescroll-downwarp-reset”

下拉刷新高度重置的动画

htmlContent

<p class="downwarp-progress"></p> <p class="downwarp-tip">下拉刷新</p>

下拉刷新的布局内容 “downwarp-progress”和”downwarp-tip”的class不要随意删掉 必须和inited的配置对应 请参考 mescroll所有配置项 的代码去配置

inited

function ( mescroll, downwarp ) { … }

下拉刷新初始化完毕的回调 (mescroll实例对象,下拉刷新容器dom对象)

inOffset

function ( mescroll ) { … }

下拉的距离进入offset范围内那一刻的回调 (mescroll实例对象)

outOffset

function ( mescroll ) { … }

下拉的距离大于offset那一刻的回调 (mescroll实例对象)

onMoving

function ( mescroll, rate, downHight ) { … }

下拉过程中的回调,滑动过程一直在执行; rate : 拉区域当前高度与指定距离的比值 ( inOffset: rate<1; outOffset: rate>=1 ) downHight : 当前下拉区域的高度

beforeLoading

function ( mescroll , downwarp ) { return false; }

准备触发下拉刷新的回调; 如果return true,将不触发showLoading和callback 常用来完全自定义下拉刷新

showLoading

function ( mescroll ) { … }

显示下拉刷新进度的回调

callback

function ( mescroll ) { mescroll.resetUpScroll(); }

下拉刷新的回调; 默认重置上拉加载列表为第一页

up 上拉加载的配置参数

参数名

默认值

说明

use

true

是否启用上拉加载 如果配置false,则不会初始化上拉加载的布局

auto

1.3.1以前版本默认false 1.3.1版本默认true

是否在初始化完毕之后自动执行一次上拉加载的回调

isLock

false

是否锁定上拉加载 如果配置true,则会锁定不可上拉,可通过调用mescroll.lockUpScroll(false)解锁

isBoth

false

上拉加载时,如果滑动到列表顶部是否可以同时触发下拉刷新

isBounce

true

是否允许ios的bounce回弹;默认true,允许回弹 (v 1.3.0新增)

offset

100

列表滚动到距离底部小于100px,即可触发上拉加载的回调

noMoreSize

5

如果列表已无数据,可设置列表的总数量要大于5条才显示无更多数据; 避免列表数据过少(比如只有一条数据),显示无更多数据会不好看

toTop

{ warpId : null , src : null , html: null , offset : 1000 , warpClass : “mescroll-totop” , showClass : “mescroll-fade-in” , hideClass : “mescroll-fade-out” , duration : 300 , supportTap : false }

回到顶部按钮的配置: warpId: 父布局的id; 默认添加在body中 (v 1.2.8 新增) src : 图片路径,必须配置src才会显示回到顶部按钮,不配置不显示 html: 标签内容,默认null; 如果同时设置了src,则优先取src (2017/12/10新增) offset : 列表滚动1000px显示回到顶部按钮 warpClass : 按钮样式 showClass : 显示样式 hideClass : 隐藏样式 duration : 回到顶部的动画时长, 默认300ms supportTap: 如果您的运行环境支持tap,则可配置true,可减少点击延时,快速响应事件;默认false,通过onclick添加点击事件; (v 1.3.0 新增) (注:微信和PC无法响应tap事件)

loadFull

{ use : false ,   delay : 500 }

use : 列表数据过少,不足以滑动触发上拉加载,是否自动加载下一页,直到满屏或无数据; 默认false,因为可调大page.size使数据满屏. delay : 延时执行的毫秒数; 延时是为了保证列表数据或占位的图片都已初始化完成,且下拉刷新上拉加载中区域动画已执行完毕;

empty

1
{ warpId : null , icon : null , tip : "暂无相关数据~" , btntext : "" ,   btnClick : null supportTap : false }

列表第一页无任何数据时,显示的空布局 需配置warpId或clearEmptyId才生效 warpId : 父布局的id; 如果此项有值,将不使用clearEmptyId的值; icon : 空布局的图标路径 tip : 提示文本 btntext : 按钮文本 btnClick : 点击按钮的回调 supportTap: 如果您的运行环境支持tap,则可配置true,可减少点击延时,快速响应事件;默认false,通过onclick添加点击事件; (v 1.3.0 新增) (注:微信和PC无法响应tap事件)

clearId

null

加载第一页时需清空数据的列表id 如果此项有值,将不使用clearEmptyId的值 在vue中使用,无需配置此项

clearEmptyId

null

相当于同时设置了clearId和empty.warpId 简化写法; 在vue中使用,无需配置此项

hardwareClass

“mescroll-hardware”

硬件加速样式,使动画更流畅

warpClass

“mescroll-upwarp”

上拉加载的布局容器样式

htmlLoading

<p class="upwarp-progress mescroll-rotate"></p><p class="upwarp-tip">加载中..</p>

上拉加载中的布局

htmlNodata

<p class="upwarp-nodata"> -- END -- </p>

无数据的布局

inited

1
function ( mescroll , upwarp ) { }

初始化完毕的回调 回调(mescroll实例, upwarp上拉加载的布局Dom对象)

showLoading

1
function ( mescroll , upwarp ) { ... }

显示上拉加载中的回调 回调(mescroll实例, upwarp上拉加载的布局Dom对象)

showNoMore

1
function ( mescroll , upwarp ) { ... }

显示无更多数据的回调 回调(mescroll实例, upwarp上拉加载的布局Dom对象)

onScroll

null

列表滑动监听, 默认null 例 onScroll : function(mescroll, y, isUp){ … }; y为列表当前滚动条的位置; isUp=true向上滑,isUp=false向下滑) isUp是1.2.1版本新增的配置,请检查最新版~

callback

1
function ( page, mescroll ) { }

上拉加载的回调; 回调 ( page对象, mescroll实例 )

page

1
{ num : 0 , size : 10 , time : null }

num : 当前页码,默认0,回调之前加1,即callback(page)从1开始; 如何修改从0开始 ? size : 每页数据的数量; time : 加载第一页数据服务器返回的时间 (可空); 防止用户翻页时,后台新增了数据从而导致下一页数据重复;

scrollbar

1
{ use : ... , barClass : "mescroll-bar" }

use : 是否开启自定义滚动条; PC端默认true开启自定义滚动条; 移动端默认false不使用 barClass : 自定义滚动条的样式;

常用方法 :

方法名

说明

1
mescroll.endByPage(dataSize, totalPage, systime); (v 1.2.1 新增)

隐藏下拉刷新和上拉加载的状态, 在联网获取数据成功后调用 dataSize : 当前页获取的数据总数(注意是当前页) totalPage : 列表的总页数 systime : 加载第一页数据的服务器时间 (可空);

1
mescroll.endBySize(dataSize, totalSize, systime); (v 1.2.1 新增)

隐藏下拉刷新和上拉加载的状态, 在联网获取数据成功后调用 dataSize : 当前页获取的数据总数(注意是当前页) totalSize : 列表的总数据量 systime : 加载第一页数据的服务器时间 (可空);

1
mescroll.endSuccess(dataSize, hasNext, systime); (v 1.2.1 调整)

隐藏下拉刷新和上拉加载的状态, 在联网获取数据成功后调用 dataSize : 当前页获取的数据量(注意是当前页) hasNext : 是否有下一页数据true/false systime : 加载第一页数据的服务器时间 (可空);

1
mescroll.endErr();

隐藏下拉刷新和上拉加载的状态, 在联网获取数据失败后调用; mescroll内部会自动恢复原来的页码,时间等变量;

1
mescroll.resetUpScroll( isShowLoading );

重置列表为第一页 (常用于列表筛选条件变化或切换菜单时重新刷新列表数据) 内部实现: 把page.num=1,再主动触发up.callback isShowLoading 是否显示进度布局; 1.默认null,不传参,则显示上拉加载的进度布局 2.传参true, 则显示下拉刷新的进度布局 3.传参false,则不显示上拉和下拉的进度 (常用于静默更新列表数据)

1
mescroll.triggerDownScroll();

主动触发下拉刷新

1
mescroll.triggerUpScroll();

主动触发上拉加载

1
mescroll.setPageNum(num); (v 1.2.5 新增)

设置当前page.num的值

1
mescroll.setPageSize(size); (v 1.2.5 新增)

设置当前page.size的值

1
mescroll.scrollTo( y, t );

滚动列表到指定位置 y=0,则回到列表顶部; 如需滚动到列表底部,可设置y很大的值,比如y=99999 t时长,单位ms,默认300; 如果不需要动画缓冲效果,则传0 (需更新至1.2.3版本)

1
mescroll.optDown;

获取下拉刷新的配置

1
mescroll.optUp;

获取上拉加载的配置

1
mescroll.lockDownScroll( isLock );

锁定下拉刷新 ( isLock=ture,null 锁定 ; isLock=false 解锁 )

1
mescroll.lockUpScroll( isLock );

锁定上拉加载 ( isLock=ture,null 锁定 ; isLock=false 解锁 )

1
2
3
4
5
mescroll.os (v 1.2.5 新增)

mescroll.os.ios 为true, 则是ios设备; mescroll.os.android 为true, 则是android设备; mescroll.os.pc 为true, 则是PC端;

mescroll.setBounce(boolean) (v 1.3.0 新增)

mescroll.setBounce(true) 允许bounce; mescroll.setBounce(false) 禁止bounce

其他方法 :

以下方法不常用,您可灵活运用于更复杂的场景

方法名

说明

1
mescroll.showDownScroll();

显示下拉刷新的进度布局 mescroll.triggerDownScroll() 和 mescroll.resetUpScroll() 内部有调用

1
mescroll.endDownScroll();

隐藏下拉刷新的进度布局 mescroll.endSuccess() 和 mescroll.endErr() 内部有调用

1
mescroll.endUpScroll(isShowNoMore)

结束上拉加载的状态 isShowNoMore=true, 显示无更多数据; isShowNoMore=false, 隐藏上拉加载; isShowNoMore=null, 保持当前状态

1
mescroll.showUpScroll();

显示上拉加载的进度布局 mescroll.triggerDownScroll() 和 mescroll.resetUpScroll() 内部有调用

1
mescroll.showNoMore();

显示上拉无更多数据的布局 mescroll.endUpScroll() 内部有调用

1
mescroll.hideUpScroll();

隐藏上拉加载的布局 mescroll.endUpScroll() 内部有调用

1
mescroll.clearDataList();

清空上拉加载的数据列表 mescroll.resetUpScroll() 和 mescroll.endSuccess() 内部有调用

1
mescroll.showEmpty();

显示无任何数据的空布局 mescroll.endSuccess() 内部有调用

1
mescroll.removeEmpty();

移除无任何数据的空布局 mescroll.endSuccess() 内部有调用

1
mescroll.showTopBtn();

显示回到顶部的按钮

1
mescroll.hideTopBtn();

隐藏回到顶部的按钮

1
mescroll.getScrollTop();

获取滚动条的位置y; 也可以在up配置onScroll监听滚动条的位置

1
mescroll.getBodyHeight();

获取body的高度

1
mescroll.getClientHeight();

获取滚动容器的高度

1
mescroll.getScrollHeight();

获取滚动内容的高度

1
mescroll.getToBottom(); (v 1.3.0新增)

获取当前滚动条到底部的距离

1
mescroll.getStep(star, end, callback, t, rate); (v 1.2.8 新增)

star : 开始值; end : 结束值; callback(step,timer) : 回调 function(step,timer), t : 计步时长; 传0则直接回调end值; 不传则默认300ms ; rate : 周期; 不传则默认30ms计步一次 ; 此方法相当于默认在300ms内,每30ms返回star到end之间的阶梯值step; 可用于模拟帧动画 比如mescroll的回到顶部缓冲动画,轮播导航案例的顶部菜单滚动都是通过getStep实现 (注: 您可根据实际情况在 callback 通过 window.clearInterval(timer) 提前结束计步器)

1
mescroll.version; (v 1.3.0新增)

mescroll的版本号

1
mescroll.destroy();

销毁mescroll

  • 版权声明: 本博客所有文章,未经许可,任何单位及个人不得做营利性使用!转载请标明出处!如有侵权请联系作者。
  • Copyrights © 2015-2023 翟天野

请我喝杯咖啡吧~