中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

小程序怎么實現分頁加載數據功能

發布時間:2020-12-15 11:26:16 來源:億速云 閱讀:353 作者:小新 欄目:移動開發

小編給大家分享一下小程序怎么實現分頁加載數據功能,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

在使用類似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: \'加載數據失敗\',
})
})
},

上面函數就是獲取音樂列表信息的請求處理邏輯,該函數有一個參數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: \'沒有更多數據\',
})
}
},

分頁功能可以更好的向用戶展示內容,留住用戶。現如今小程序作為用戶獲取信息的新渠道,很多小程序已經有了分頁功能,在實現這一功能最好結合數據,如果處理不當容易導致數據丟失,造成不必要損失。

看完了這篇文章,相信你對小程序怎么實現分頁加載數據功能有了一定的了解,想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

滦南县| 安丘市| 泊头市| 南开区| 砀山县| 静安区| 伊春市| 吉隆县| 贵港市| 高安市| 云林县| 贺兰县| 宝丰县| 黔西| 荆州市| 盖州市| 离岛区| 华安县| 南宫市| 郑州市| 天峻县| 高邑县| 永城市| 保山市| 玛沁县| 扎赉特旗| 汝州市| 成武县| 永修县| 鹿邑县| 黎川县| 江山市| 阿鲁科尔沁旗| 汝南县| 江西省| 沭阳县| 丰镇市| 香河县| 玉田县| 城步| 全州县|