微信小程序上滑加载下拉刷新(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 相关文章推荐
用脚本调用样式的几种方法
Dec 09 Javascript
JQUERY的属性选择符和自定义选择符使用方法(二)
Apr 07 Javascript
解析jQuery的三种bind/One/Live事件绑定使用方法
Dec 30 Javascript
jquery中用jsonp实现搜索框功能
Oct 18 Javascript
ReactNative短信验证码倒计时控件的实现代码
Jul 20 Javascript
angular写一个列表的选择全选交互组件的示例
Jan 22 Javascript
详解vue 计算属性与方法跟侦听器区别(面试考点)
Apr 23 Javascript
vue打包使用Nginx代理解决跨域问题
Aug 27 Javascript
微信小程序使用canvas的画图操作示例
Jan 18 Javascript
Vue+Express实现登录状态权限验证的示例代码
May 05 Javascript
javascript 关于赋值、浅拷贝、深拷贝的个人理解
Nov 01 Javascript
jQuery使用jsonp实现百度搜索的示例代码
Jul 08 jQuery
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作的文本留言本的例子(一)
2006/10/09 PHP
PHP实现设计模式中的抽象工厂模式详解
2014/10/11 PHP
记录Yii2框架开发微信公众号遇到的问题及解决方法
2018/07/20 PHP
Laravel框架FormRequest中重写错误处理的方法
2019/02/18 PHP
Laravel如何实现适合Api的异常处理响应格式
2020/06/14 PHP
符合W3C网页标准的iframe标签的使用方法
2007/07/19 Javascript
Chrome Form多次提交表单问题的解决方法
2011/05/09 Javascript
js实现的仿新浪微博完美的时间组件升级版
2011/12/20 Javascript
Jquery搜索父元素操作方法
2015/02/10 Javascript
javascript实现列表切换效果
2016/05/02 Javascript
js判断输入字符串是否为空、空格、null的方法总结
2016/06/14 Javascript
JS前端加密算法示例
2016/12/22 Javascript
jQuery中的一些小技巧
2017/01/18 Javascript
jQuery实现的动态文字变化输出效果示例【附演示与demo源码下载】
2017/03/24 jQuery
JavaScript切换搜索引擎的导航网页搜索框实例代码
2017/06/11 Javascript
让nodeJS支持ES6的词法----babel的安装和使用方法
2017/07/31 NodeJs
Bootstrap实现可折叠分组侧边导航菜单
2018/03/07 Javascript
微信小程序websocket实现聊天功能
2020/03/30 Javascript
Python实现将n个点均匀地分布在球面上的方法
2015/03/12 Python
tensorflow学习笔记之简单的神经网络训练和测试
2018/04/15 Python
python 划分数据集为训练集和测试集的方法
2018/12/11 Python
python 初始化一个定长的数组实例
2019/12/02 Python
浅谈Python3实现两个矩形的交并比(IoU)
2020/01/18 Python
filter使用python3代码进行迭代元素的实例详解
2020/12/03 Python
10个python爬虫入门基础代码实例 + 1个简单的python爬虫完整实例
2020/12/16 Python
python 下载文件的几种方法汇总
2021/01/06 Python
一款利用html5和css3动画排列人物头像的实例演示
2014/12/05 HTML / CSS
英国奢侈品在线精品店:Hervia
2020/09/03 全球购物
本科生学习总结的自我评价
2013/10/02 职场文书
《找不到快乐的波斯猫》教学反思
2014/02/24 职场文书
群众路线教育党课主持词
2014/04/01 职场文书
承兑汇票转让证明怎么写?
2014/11/30 职场文书
有关骆驼祥子的读书笔记
2015/06/26 职场文书
担保书怎么写 ?
2019/04/22 职场文书
人民币符号
2022/02/17 杂记
Python中np.random.randint()参数详解及用法实例
2022/09/23 Python