首頁 >微信小程式 >小程式開發 >小程式如何實作分頁載入資料功能?

小程式如何實作分頁載入資料功能?

青灯夜游
青灯夜游轉載
2020-05-07 09:18:444178瀏覽

小程式如何實現分頁載入資料功能?下面這篇文章跟大家介紹一下。有一定的參考價值,有需要的朋友可以參考一下,希望對大家有幫助。

小程式如何實作分頁載入資料功能?

在使用類似qq,微博或新聞類等資料量大的應用經常會遇到分頁載入功能,它不僅的應用場景廣,還能挺高使用者體驗。微信小程式中也可以分頁載入數據,這篇文章就是介紹微信小程式怎麼製作分頁載入資料

要實現這樣的功能,一般需要在請求資料時加入目前請求頁數,以及頁的大小(每頁顯示的數量)也有一部分介面是透過請求的開始偏移量和結束偏移量請求數據,例如你一頁顯示10條數據,第一次(第一頁)請求即開始start為0結束end是9,第二頁就是從10到19,以此類推。既然要實現分頁載入功能,最重要就是下拉以及上拉的處理事件,在微信小程式中已經幫我們封裝好了上拉以及下拉的觸發事件,如下

/**
* 页面相关事件处理函数--监听用户下拉动作
*/
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,並將頁數page加1.當下拉的時候講page先更改為1,然後去查詢數據,當查詢數據成功時,如果page為1,就將獲取的數據直接賦值為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: \&#39;加载数据失败\&#39;,
})
})
},

上面函數就是獲取音樂列表信息的請求處理邏輯,該函數有一個參數message,它是用來展示加載數據時的提示信息,例如當下拉的時候,提示信息為正在刷新數據,當上拉的時候提示正在加載更多數據。

那麼我們當進入頁面的時候開始載入一次數據,即在onLoad函數,如下

onLoad: function (options) {
// 页面初始化 options为页面跳转所带来的参数
var that = this
that.getMusicInfo(\&#39;正在加载数据...\&#39;)
},

然後上拉和下拉函數的實作如下

/**
* 页面相关事件处理函数--监听用户下拉动作
*/
onPullDownRefresh:function () {
this.data.page = 1
this.getMusicInfo(\&#39;正在刷新数据\&#39;)
},
/**
* 页面上拉触底事件的处理函数
*/
onReachBottom: function() {
if(this.data.hasMoreData) {
this.getMusicInfo(\&#39;加载更多数据\&#39;)
} else {
wx.showToast({
title: \&#39;没有更多数据\&#39;,
})
}
},

分頁功能可以更好的向使用者展示內容,留住使用者。現如今小程式作為用戶獲取資訊的新管道,許多小程式已經有了分頁功能,在實現這項功能最好結合數據,如果處理不當容易導致數據遺失,造成不必要損失。

推薦:《小程式開發教學

以上是小程式如何實作分頁載入資料功能?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:jisuapp.cn。如有侵權,請聯絡admin@php.cn刪除