微信小程序上滑加载下拉刷新(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 相关文章推荐
javascript 图片裁剪技巧解读
Nov 15 Javascript
js使用eval解析json(js中使用json)
Jan 17 Javascript
js 动态修改css文件用到了cssRule
Aug 20 Javascript
JavaScript中字符串拼接的基本方法
Jul 07 Javascript
基于jquery css3实现点击动画弹出表单源码特效
Aug 31 Javascript
从重置input file标签中看jQuery的 .val() 和 .attr(“value”) 区别
Jun 12 Javascript
AngularJS 中的Promise --- $q服务详解
Sep 14 Javascript
利用JS判断字符串是否含有数字与特殊字符的方法小结
Nov 25 Javascript
BootStrap表单验证实例代码
Jan 13 Javascript
5分钟打造简易高效的webpack常用配置
Jul 04 Javascript
Vuejs 2.0 子组件访问/调用父组件的方法(示例代码)
Feb 08 Javascript
node.js的Express服务器基本使用教程
Jan 09 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
php jquery 实现新闻标签分类与无刷新分页
2009/12/18 PHP
php feof用来识别文件末尾字符的方法
2010/08/01 PHP
php中可能用来加密字符串的函数[base64_encode、urlencode、sha1]
2012/01/16 PHP
php Ubb代码编辑器函数代码
2012/07/05 PHP
PHP中全局变量global和$GLOBALS[]的区别分析
2012/08/06 PHP
PHP实现绘制3D扇形统计图及图片缩放实例
2014/10/01 PHP
php获取当月最后一天函数分享
2015/02/02 PHP
PHP中ltrim与rtrim去除左右空格及特殊字符实例
2016/01/07 PHP
PHP7新特性foreach 修改示例介绍
2016/08/26 PHP
jquery如何判断表格同一列不同行input数据是否重复
2014/05/14 Javascript
node.js中的fs.fchmod方法使用说明
2014/12/16 Javascript
jQuery 1.9.1源码分析系列(十五)之动画处理
2015/12/03 Javascript
Angular实现响应式表单
2017/08/04 Javascript
Grunt针对静态文件的压缩,版本控制打包的实例讲解
2017/09/29 Javascript
原生js添加一个或多个类名的方法分析
2019/07/30 Javascript
vue源码nextTick使用及原理解析
2019/08/13 Javascript
element-ui中dialog弹窗关闭按钮失效的解决
2020/09/22 Javascript
跟老齐学Python之使用Python查询更新数据库
2014/11/25 Python
在Python中使用cookielib和urllib2配合PyQuery抓取网页信息
2015/04/25 Python
在Python中操作字符串之startswith()方法的使用
2015/05/20 Python
Python中subprocess的简单使用示例
2015/07/28 Python
python利用matplotlib库绘制饼图的方法示例
2016/12/18 Python
Python使用matplotlib绘制余弦的散点图示例
2018/03/14 Python
深入理解Python中的 __new__ 和 __init__及区别介绍
2018/09/17 Python
Python devel安装失败问题解决方案
2020/06/09 Python
ffmpeg+Python实现B站MP4格式音频与视频的合并示例代码
2020/10/21 Python
Manduka官网:瑜伽垫、瑜伽毛巾和服装
2018/07/02 全球购物
如何通过 CSS 写出火焰效果
2021/03/24 HTML / CSS
材料物理专业大学毕业生求职信
2013/10/15 职场文书
销售主管岗位职责范本
2014/02/14 职场文书
校园环境卫生倡议书
2015/04/29 职场文书
2015小学教师年度工作总结
2015/05/12 职场文书
毕业论文答辩稿范文
2015/06/23 职场文书
SQL基础查询和LINQ集成化查询
2022/01/18 MySQL
Redis 操作多个数据库的配置的方法实现
2022/03/23 Redis
Win11软件图标固定到任务栏
2022/04/19 数码科技