欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

微信小程序分頁加載的實例代碼

 更新時間:2017年07月11日 11:55:50   作者:Code4Android  
本篇文章主要介紹了微信小程序分頁加載的實例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

整理文檔,搜刮出一個微信小程序分頁加載的代碼,稍微整理精簡一下做下分享。

分頁加載功能大家遇到的應該會經(jīng)常遇到,應用場景也很多,例如微博,QQ,微信朋友圈以及新聞類應用,都會有分頁加載的功能,這不僅節(jié)省了我們用戶的流量,還提升了用戶體驗。那么今天的這篇文章就是介紹微信小程序中如何實現(xiàn)分頁加載的功能。照例先上源碼及效果圖。

源碼傳送門


要實現(xiàn)這樣的功能,一般需要在請求數(shù)據(jù)時加入當前請求頁數(shù),以及頁的大?。宽擄@示的數(shù)量)也有一部分接口是通過請求的開始偏移量和結束偏移量請求數(shù)據(jù),例如你一頁顯示10條數(shù)據(jù),第一次(第一頁)請求即開始start為0結束end是9,第二頁就是從10到19,以此類推。

既然要實現(xiàn)分頁加載功能,最重要就是下拉以及上拉的處理事件,在微信小程序中已經(jīng)幫我們封裝好了上拉以及下拉的觸發(fā)事件,如下

/**
 * 頁面相關事件處理函數(shù)--監(jiān)聽用戶下拉動作
 */
 onPullDownRefresh: function () {
 },

 /**
  * 頁面上拉觸底事件的處理函數(shù)
  */
 onReachBottom: function () {
 },

可能剛接觸微信小程序的愛好者,會遇到一個問題,為什么我重寫了上拉和下拉函數(shù),但是當我上拉或者下拉的時候函數(shù)為什么不回調啊。莫急莫慌,那是因為除了重寫這兩個函數(shù),我們還需要在json配置文件加入下面代碼

{
  "enablePullDownRefresh": true
}

有了上面的代碼,我們每次上拉或者下拉就會觸發(fā)相對應的函數(shù)了。

在data中創(chuàng)建數(shù)據(jù)

 data: {
  page: 1,
  pageSize: 30,
  hasMoreData: true,
  contentlist: [],
 },

page即為當前請求數(shù)據(jù)時第幾頁,pageSize是每頁的數(shù)據(jù)的大小,hasMoreData用于上拉的時候是不是要繼續(xù)請求數(shù)據(jù),即是不是還有更多數(shù)據(jù)。當我們網(wǎng)絡請求數(shù)據(jù)成功后,如果請求數(shù)據(jù)的長度小于pageSize: 30,那么就表示沒有更多數(shù)據(jù),將hasMoreData更改為false,如果請求的數(shù)據(jù)長度是30,表示還有更多數(shù)據(jù)那么hasMoreData久更改為true,并將頁數(shù)page加1.當下拉的時候講page先更改為1,然后去查詢數(shù)據(jù),當查詢數(shù)據(jù)成功時,如果page為1,就將獲取的數(shù)據(jù)直接賦值給contentlist,如果頁數(shù)大于1的話,就將請求的數(shù)據(jù)追加在contentlist后面。這樣就可以實現(xiàn)分頁加載的功能了。

經(jīng)過上面的分析,我們已經(jīng)對分頁加載的實現(xiàn)有了一個清晰的認識,那么接下來我就介紹代碼的實現(xiàn)。

 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: '加載數(shù)據(jù)失敗',
   })

  })
 },

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

那么我們當進入頁面的時候開始加載一次數(shù)據(jù),即在onLoad函數(shù),如下

 onLoad: function (options) {
  // 頁面初始化 options為頁面跳轉所帶來的參數(shù)
  var that = this
  that.getMusicInfo('正在加載數(shù)據(jù)...')
 },

然后上拉和下拉函數(shù)的實現(xiàn)如下

 /**
 * 頁面相關事件處理函數(shù)--監(jiān)聽用戶下拉動作
 */
 onPullDownRefresh: function () {
  this.data.page = 1
  this.getMusicInfo('正在刷新數(shù)據(jù)')
 },

 /**
  * 頁面上拉觸底事件的處理函數(shù)
  */
 onReachBottom: function () {
  if (this.data.hasMoreData) {
   this.getMusicInfo('加載更多數(shù)據(jù)')
  } else {
   wx.showToast({
    title: '沒有更多數(shù)據(jù)',
   })
  }
 },

  以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • JS實現(xiàn)重新加載當前頁面

    JS實現(xiàn)重新加載當前頁面

    本文主要介紹用JavaScript刷新上級頁面和當前頁面。附上具體實例代碼。需要的朋友可以參考下
    2016-11-11
  • javascript獲取鼠標點擊元素對象(示例代碼)

    javascript獲取鼠標點擊元素對象(示例代碼)

    本篇文章主要介紹了利用javascript獲取鼠標點擊元素對象的示例代碼。需要的朋友可以過來參考下,希望對大家有所幫助
    2013-12-12
  • javaScript中的空值和假值

    javaScript中的空值和假值

    JavaScript 是世界上最流行的編程語言。javaScript中有五種空值和假值,分別為false,null,undefined,“”,0。從廣義上來說,這五個值都是對應數(shù)據(jù)類型的無效值或空值
    2017-12-12
  • JavaScript識別網(wǎng)頁關鍵字并進行描紅的方法

    JavaScript識別網(wǎng)頁關鍵字并進行描紅的方法

    這篇文章主要介紹了JavaScript識別網(wǎng)頁關鍵字并進行描紅的方法,通過字符串的遍歷、匹配及動態(tài)添加等操作實現(xiàn)識別與描紅的功能,非常簡單實用,需要的朋友可以參考下
    2015-11-11
  • 淺談如何優(yōu)雅處理JavaScript異步錯誤

    淺談如何優(yōu)雅處理JavaScript異步錯誤

    這篇文章主要介紹了淺談如何優(yōu)雅處理JavaScript異步錯誤,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • 基于BootstrapValidator的Form表單驗證(24)

    基于BootstrapValidator的Form表單驗證(24)

    這篇文章主要為大家詳細介紹了基于BootstrapValidator的Form表驗證,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • vscode錄音及語音實時轉寫插件開發(fā)并在工作區(qū)生成本地mp3文件附踩坑日記!

    vscode錄音及語音實時轉寫插件開發(fā)并在工作區(qū)生成本地mp3文件附踩坑日記!

    以目前的vscode版本來說,作者并沒有開放訪問本地媒體權限,所以插件市場里面的所有語音相關插件也并沒有直接獲取vscode的媒體權限,這篇文章主要介紹了vscode錄音及語音實時轉寫插件開發(fā)并在工作區(qū)生成本地mp3文件?踩坑日記!,需要的朋友可以參考下
    2023-05-05
  • 微信小程序實現(xiàn)自定義底部導航

    微信小程序實現(xiàn)自定義底部導航

    這篇文章主要為大家詳細介紹了微信小程序實現(xiàn)自定義底部導航,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Openlayers實現(xiàn)地圖的基本操作

    Openlayers實現(xiàn)地圖的基本操作

    這篇文章主要為大家詳細介紹了Openlayers實現(xiàn)地圖的基本操作,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • Web純前端“旭日圖”實現(xiàn)元素周期表

    Web純前端“旭日圖”實現(xiàn)元素周期表

    本文主要介紹了Web純前端“旭日圖”實現(xiàn)元素周期表的實例解析。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03

最新評論