当前位置: 首页 > 微信相关

微信小程序怎么制作分页加载数据

发布日期:2020-08-12 09:07:22 分类:微信相关 阅读()来源:网络收集

好东西要多分享:

做网站就上魔艺客
摘要:许多应用经常会遇到分页加载功能,能挺高用户体验。微信小程序中也可以分页加载数据。

在使用类似qq,微博或者新闻类等数据量大的应用经常会遇到分页加载功能,它不仅的应用场景广,还能挺高用户体验。微信小程序中也可以分页加载数据,这篇文章就是介绍微信小程序怎么制作分页加载数据


要实现这样的功能,一般需要在请求数据时加入当前请求页数,以及页的大小(每页显示的数量)也有一部分接口是通过请求的开始偏移量和结束偏移量请求数据,例如你一页显示10条数据,第一次(第一页)请求即开始start0结束end9,第二页就是从1019,以此类推。既然要实现分页加载功能,最重要就是下拉以及上拉的处理事件,在微信小程序中已经帮我们封装好了上拉以及下拉的触发事件,如下

/**

* 页面相关事件处理函数--监听用户下拉动作

*/

onPullDownRefresh:function () {

},

/**

* 页面上拉触底事件的处理函数

*/

onReachBottom: function() {

},

可能刚接触微信小程序的爱好者,会遇到一个问题,为什么我重写了上拉和下拉函数,但是当我上拉或者下拉的时候函数为什么不回调啊。莫急莫慌,那是因为除了重写这两个函数,我们还需要在json配置文件加入下面代码

{

enablePullDownRefresh: true

}

有了上面的代码,我们每次上拉或者下拉就会触发相对应的函数了。

data中创建数据

data: {

page: 1,

pageSize: 30,

hasMoreData: true,

contentlist: [],

},

page即为当前请求数据时第几页,pageSize是每页的数据的大小,hasMoreData用于上拉的时候是不是要继续请求数据,即是不是还有更多数据。当我们网络请求数据成功后,如果请求数据的长度小于pageSize: 30,那么就表示没有更多数据,将hasMoreData更改为false,如果请求的数据长度是30,表示还有更多数据那么hasMoreData久更改为true,并将页数page1.当下拉的时候讲page先更改为1,然后去查询数据,当查询数据成功时,如果page1,就将获取的数据直接赋值给contentlist,如果页数大于1的话,就将请求的数据追加在contentlist后面。这样就可以实现分页加载的功能了。

经过上面的分析,我们已经对分页加载的实现有了一个清晰的认识,那么接下来我就介绍代码的实现。

getMusicInfo: function (message) {

var that = this

var data = {

showapi_appid:'25158',

showapi_sign:'c0d685445898438f8c12ee8e93c2ee74',

keyword: '我',

page:that.data.page

}

network.requestLoading('https://route.showapi.com/213-1', data, message,function (res) {

console.log(res)

var contentlistTem= that.data.contentlist

if(res.showapi_res_code == 0) {

if(that.data.page == 1) {

contentlistTem= []

}

var contentlist =res.showapi_res_body.pagebean.contentlist

if(contentlist.length < that.data.pageSize) {

that.setData({

contentlist:contentlistTem.concat(contentlist),

hasMoreData:false

})

} else {

that.setData({

contentlist:contentlistTem.concat(contentlist),

hasMoreData:true,

page:that.data.page + 1

})

}

} else {

wx.showToast({

title: res.showapi_res_error,

})

}


}, function (res) {

wx.showToast({

title: '加载数据失败',

})


})

},

上面函数就是获取音乐列表信息的请求处理逻辑,该函数有一个参数message,它是用来展示加载数据时的提示信息,例如当下拉的时候,提示信息为正在刷新数据,当上拉的时候提示正在加载更多数据。

那么我们当进入页面的时候开始加载一次数据,即在onLoad函数,如下

onLoad: function (options) {

// 页面初始化 options为页面跳转所带来的参数

var that = this

that.getMusicInfo('正在加载数据...')

},

然后上拉和下拉函数的实现如下

/**

* 页面相关事件处理函数--监听用户下拉动作

*/

onPullDownRefresh:function () {

this.data.page = 1

this.getMusicInfo('正在刷新数据')

},


/**

* 页面上拉触底事件的处理函数

*/

onReachBottom: function() {

if(this.data.hasMoreData) {

this.getMusicInfo('加载更多数据')

} else {

wx.showToast({

title: '没有更多数据',

})

}

},

分页功能可以更好的向用户展示内容,留住用户。现如今小程序作为用户获取信息的新渠道,很多小程序已经有了分页功能,在实现这一功能最好结合数据,如果处理不当容易导致数据丢失,造成不必要损失。


推荐阅读:微信小程序下拉刷新实现方法

声明: 文章内容及图片部分全部摘自网络,在此分享供读者参考和借鉴,不代表酷雷的观点。文章、图片等内容如涉嫌侵权,请联系我们删除,谢谢!带有原创标签的属于酷雷原创文章,未经允许不得转载!

标签:

我要说一说

加载中~

相关推荐

您好,很高兴为您服务!
广告合作
投诉建议
联系站长

客服热线:15821432298

扫码加好友,优惠等你来!