微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)


Posted in Javascript onMay 11, 2017

微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(一)

页面缓存的设置优化了页面加载,减少了频繁的调取接口,使用户在断网的情况下有更好的体验。

每个微信小程序都可以有自己的本地缓存,可以通过 wx.setStorage(wx.setStorageSync)、wx.getStorage(wx.getStorageSync)、wx.clearStorage(wx.clearStorageSync)可以对本地缓存进行设置、获取和清理。本地缓存最大为10MB。

注意: localStorage 是永久存储的,但是我们不建议将关键信息全部存在 localStorage,以防用户换设备的情况。

项目需求

通过使用scroll-view 自定义的鼠标滚动事件onscrollLower,监听页面下拉事件

page.init()的方法里封装了请求数据的接口,后台api文档自带分页pageSize,默认值为10,-1为请求全部数据。

说明:

触发下滑事件通过与页面data缓存数据对比,去请求接口。

代码实现

var n=0
 page.init = function(callback) {
 page.data.loading = true;
 n+=10;
 cardService.listFavoriteCards(n,function(result){
 var cards = result.data.favoriteCards; 
 var starCards = result.data.starCards;

 starCards.sort(function(c1,c2){
 var c1Name = pinyingUtil.getInitials.convertPinyin(c1.name);
 var c2Name = pinyingUtil.getInitials.convertPinyin(c2.name);

 return c1Name > c2Name ? 1 : -1;
 });

 if(starCards && starCards.length> 0) {
 starCards.forEach(function(c){
 var compressEntName = dictService.compressEntName(c.companyName);
 c.compressEntName = compressEntName;
 });
 }

 page.setData({
 "favoriteCards" : cards,
 "starCards" : starCards,
 "filterType" : "name",
 "groups" : cardService.groupCardsByNameFirstLetter(cards),
 "loadding":false
 });
 wx.setStorageSync("setgroups",page.data.groups)
 });
 };

}
onLoad: function (options) {

 var geigroups=wx.getStorageSync('setgroups')
 var result =[]
 for(var i=0; i<geigroups.length; i+=5){
 result.push(geigroups.slice(i,i+5));
 }
 var resultd=result[0]
 if(geigroups){ 
 page.setData({
 "groups" : resultd
 }); 
 console.log('缓存')
 }else{
 if (wx.getStorageSync("token")) {
 page.init();
 page.initProfile();
 } else {
 App.addListener("evt_login", function () {
 page.init();
 page.initProfile();
 });
 }
 console.log('正常')
 }
}
onscrollLower:function(){
 var page = this;
 var geigroups=wx.getStorageSync('setgroups') //第一步拿数据
 var result =[] //定义空数组
 var n=0; //定义index
 for(var i=0; i<geigroups.length; i+=10){
 result.push(geigroups.slice(i,i+10));
 } //把数据每10个一组push到 result里面
 n+=1;

 var q=this.data.groups.length;
 if(geigroups){ //如果有缓存
 if(geigroups.length<=q) //如果当前data的数据少于缓存执行以下命令
 if (wx.getStorageSync("token")) { //如果有token请求数据
 page.init();
 page.initProfile();
 } else {
 App.addListener("evt_login", function () { //监听用户登陆以后 请求数据
 page.init();
 page.initProfile();
 });
 }

 }else{
 page.setData({
 "groups" : result[n], 
 }); 
 }
 },

总结

加载数据的几种方法:

方法一:onPullDownRefresh和onReachBottom方法实现小程序下拉加载和上拉刷新

方法二:在scroll-view里设定bindscrolltoupper和bindscrolltolower实现微信小程序下拉

因项目需求采用方法二去实现,结合本地储存是这次的难点,希望对大家有帮助,有不足的地方大家多提建议,共勉。

 相关文章:微信小程序上滑加载下拉刷新(onscrollLower)分批加载数据(二)

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

Javascript 相关文章推荐
网页右键ie不支持event.preventDefault和event.returnValue (需要加window)
Feb 22 Javascript
JS幻灯片可循环播放可平滑旋转带滚动导航(自写)
Aug 05 Javascript
使用JQuery库提供的扩展功能实现自定义方法
Sep 09 Javascript
JavaScript函数定义的常见注意事项小结
Sep 16 Javascript
jQuery弹出层插件Lightbox_me使用指南
Apr 21 Javascript
Bootstrap每天必学之面板
Nov 30 Javascript
JS作为值的函数用法示例
Jun 20 Javascript
jQuery实现点击弹出背景变暗遮罩效果实例代码
Jun 24 Javascript
React Native基础入门之初步使用Flexbox布局
Jul 02 Javascript
详解webpack+ES6+Sass搭建多页面应用
Nov 05 Javascript
javascript中this的用法实践分析
Jul 29 Javascript
js脚本中执行java后台代码方法解析
Oct 11 Javascript
JS实现的四级密码强度检测功能示例
May 11 #Javascript
详解Vue中状态管理Vuex
May 11 #Javascript
JS简单生成随机数(随机密码)的方法
May 11 #Javascript
ionic实现下拉刷新载入数据功能
May 11 #Javascript
vue2的todolist入门小项目的详细解析
May 11 #Javascript
ionic实现底部分享功能
May 11 #Javascript
学习使用Bootstrap栅格系统
May 11 #Javascript
You might like
星际争霸中的对战模式介绍
2020/03/04 星际争霸
php设计模式 Prototype (原型模式)代码
2011/06/26 PHP
PHP操作Memcache实例介绍
2013/06/14 PHP
PHP中preg_match函数正则匹配的字符串长度问题
2015/05/27 PHP
laravel csrf排除路由,禁止,关闭指定路由的例子
2019/10/21 PHP
PHP mkdir创建文件夹实现方法解析
2020/11/13 PHP
VBScript版代码高亮
2006/06/26 Javascript
鼠标事件延时切换插件
2011/03/12 Javascript
jQuery判断div随滚动条滚动到一定位置后停止
2014/04/02 Javascript
checkbox选中与未选中判断示例
2014/08/04 Javascript
15个jquery常用方法、小技巧分享
2015/01/13 Javascript
kindeditor修复会替换script内容的问题
2015/04/03 Javascript
JavaScript中的toDateString()方法使用详解
2015/06/12 Javascript
JavaScript实现输入框(密码框)出现提示语
2016/01/12 Javascript
AngularJS数据源的多种获取方式汇总
2016/02/02 Javascript
移动端翻页插件dropload.js(支持Zepto和jQuery)
2016/07/27 Javascript
Node.js 日志处理模块log4js
2016/08/28 Javascript
正则表达式替换html元素属性的方法
2016/11/26 Javascript
vue.js利用defineProperty实现数据的双向绑定
2017/04/28 Javascript
VueJs使用Amaze ui调整列表和内容页面
2017/11/30 Javascript
JS实现点击li标签弹出对应的索引功能【案例】
2019/02/18 Javascript
详解JS实现简单的时分秒倒计时代码
2019/04/25 Javascript
vue 中几种传值方法(3种)
2019/11/12 Javascript
vue实现按钮切换图片
2021/01/20 Vue.js
[01:48]帕吉至宝加入游戏,遗迹战场现“千劫神屠”
2018/04/07 DOTA
python编写朴素贝叶斯用于文本分类
2017/12/21 Python
Python实现输出某区间范围内全部素数的方法
2018/05/02 Python
windows下python安装pip图文教程
2018/05/25 Python
绝对经典成功的大学生推荐信
2013/11/08 职场文书
酒店公关部经理岗位职责
2013/11/24 职场文书
新学期开学寄语
2014/01/18 职场文书
利群广告词
2014/03/20 职场文书
质量保证书怎么写
2015/02/27 职场文书
九年级语文教学反思
2016/03/03 职场文书
python 三边测量定位的实现代码
2021/04/22 Python
千万级用户系统SQL调优实战分享
2022/03/03 MySQL