分頁加載功能你們遇到的應該會常常遇到,應用場景也不少,例如微博,QQ,微信朋友圈以及新聞類應用,都會有分頁加載的功能,這不只節省了咱們用戶的流量,還提高了用戶體驗。那麼今天的這篇文章就是介紹微信小程序中如何實現分頁加載的功能。照例先上源碼及效果圖。git
源碼傳送門github
要實現這樣的功能,通常須要在請求數據時加入當前請求頁數,以及頁的大小(每頁顯示的數量)也有一部分接口是經過請求的開始偏移量和結束偏移量請求數據,例如你一頁顯示10條數據,第一次(第一頁)請求即開始start爲0結束end是9,第二頁就是從10到19,以此類推。json
既然要實現分頁加載功能,最重要就是下拉以及上拉的處理事件,在微信小程序中已經幫咱們封裝好了上拉以及下拉的觸發事件,以下小程序
/**
* 頁面相關事件處理函數--監聽用戶下拉動做
*/
onPullDownRefresh: function () {
},
/**
* 頁面上拉觸底事件的處理函數
*/
onReachBottom: function () {
},複製代碼
可能剛接觸微信小程序的愛好者,會遇到一個問題,爲何我重寫了上拉和下拉函數,可是當我上拉或者下拉的時候函數爲何不回調啊。莫急莫慌,那是由於除了重寫這兩個函數,咱們還須要在json配置文件加入下面代碼微信小程序
{
"enablePullDownRefresh": true
}複製代碼
有了上面的代碼,咱們每次上拉或者下拉就會觸發相對應的函數了。
在data中建立數據api
data: {
page: 1,
pageSize: 30,
hasMoreData: true,
contentlist: [],
},複製代碼
page即爲當前請求數據時第幾頁,pageSize是每頁的數據的大小,hasMoreData用於上拉的時候是否是要繼續請求數據,便是不是還有更多數據。當咱們網絡請求數據成功後,若是請求數據的長度小於pageSize: 30,那麼就表示沒有更多數據,將hasMoreData更改成false,若是請求的數據長度是30,表示還有更多數據那麼hasMoreData久更改成true,並將頁數page加1.當下拉的時候講page先更改成1,而後去查詢數據,當查詢數據成功時,若是page爲1,就將獲取的數據直接賦值給contentlist,若是頁數大於1的話,就將請求的數據追加在contentlist後面。這樣就能夠實現分頁加載的功能了。bash
通過上面的分析,咱們已經對分頁加載的實現有了一個清晰的認識,那麼接下來我就介紹代碼的實現。微信
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('正在加載數據...')
},複製代碼
而後上拉和下拉函數的實現以下app
/**
* 頁面相關事件處理函數--監聽用戶下拉動做
*/
onPullDownRefresh: function () {
this.data.page = 1
this.getMusicInfo('正在刷新數據')
},
/**
* 頁面上拉觸底事件的處理函數
*/
onReachBottom: function () {
if (this.data.hasMoreData) {
this.getMusicInfo('加載更多數據')
} else {
wx.showToast({
title: '沒有更多數據',
})
}
},複製代碼