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

Vue?uni-app框架實現(xiàn)上拉加載下拉刷新功能

 更新時間:2022年09月07日 10:45:19   作者:船長在船上  
uni-app是一個使用Vue.js(opens?new?window)開發(fā)所有前端應用的框架,開發(fā)者編寫一套代碼,可發(fā)布到iOS、Android、Web(響應式)、以及各種小程序(微信/支付寶/百度/頭條/飛書/QQ/快手/釘釘/淘寶)、快應用等多個平臺

實現(xiàn)上拉加載更多

打開項目根目錄中的pages.json配置文件,為subPackages分包中的商品goods_list頁面配置上拉觸底的距離:

"subPackages": [
   {
     "root": "subpkg",
     "pages": [
       {
         "path": "goods_detail/goods_detail",
         "style": {}
       },
       {
         "path": "goods_list/goods_list",
         "style": {
           "onReachBottomDistance": 150
         }
       },
       {
         "path": "search/search",
         "style": {}
       }
     ]
   }
 ]

goods_list頁面中,和methods節(jié)點平級,聲明onReachBottom事件處理函數(shù),用來監(jiān)聽頁面的上拉觸底行為:

// 觸底的事件
onReachBottom() {
  // 讓頁碼值自增 +1
  this.queryObj.pagenum += 1
  // 重新獲取列表數(shù)據(jù)
  this.getGoodsList()
}

改造methods中的getGoodsList函數(shù),當列表數(shù)據(jù)請求成功之后,進行新舊數(shù)據(jù)的拼接處理:

// 獲取商品列表數(shù)據(jù)的方法
async getGoodsList() {
  // 發(fā)起請求
  const { data: res } = await uni.$http.get('/api/public/v1/goods/search', this.queryObj)
  if (res.meta.status !== 200) return uni.$showMsg()
  // 為數(shù)據(jù)賦值:通過展開運算符的形式,進行新舊數(shù)據(jù)的拼接
  this.goodsList = [...this.goodsList, ...res.message.goods]
  this.total = res.message.total
}

優(yōu)化

通過節(jié)流閥防止發(fā)起額外的請求

在 data 中定義isloading節(jié)流閥如下:

data() {
  return {
    // 是否正在請求數(shù)據(jù)
    isloading: false
  }
}

修改getGoodsList方法,在請求數(shù)據(jù)前后,分別打開和關閉節(jié)流閥:

// 獲取商品列表數(shù)據(jù)的方法
async getGoodsList() {
  // ** 打開節(jié)流閥
  this.isloading = true
  // 發(fā)起請求
  const { data: res } = await uni.$http.get('/api/public/v1/goods/search', this.queryObj)
  // ** 關閉節(jié)流閥
  this.isloading = false
  // 省略其它代碼...
}

onReachBottom觸底事件處理函數(shù)中,根據(jù)節(jié)流閥的狀態(tài),來決定是否發(fā)起請求:

// 觸底的事件
onReachBottom() {
  // 判斷是否正在請求其它數(shù)據(jù),如果是,則不發(fā)起額外的請求
  if (this.isloading) return
  this.queryObj.pagenum += 1
  this.getGoodsList()
}

判斷數(shù)據(jù)是否加載完畢

如果下面的公式成立,則證明沒有下一頁數(shù)據(jù)了:

當前的頁碼值 * 每頁顯示多少條數(shù)據(jù) >= 總數(shù)條數(shù)
pagenum * pagesize >= total

修改onReachBottom事件處理函數(shù)如下:

// 觸底的事件
onReachBottom() {
  // 判斷是否還有下一頁數(shù)據(jù)
  if (this.queryObj.pagenum * this.queryObj.pagesize >= this.total) return uni.$showMsg('數(shù)據(jù)加載完畢!')
  // 判斷是否正在請求其它數(shù)據(jù),如果是,則不發(fā)起額外的請求
  if (this.isloading) return
  this.queryObj.pagenum += 1
  this.getGoodsList()
}

實現(xiàn)下拉刷新

pages.json配置文件中,為當前的goods_list頁面單獨開啟下拉刷新效果:

"subPackages": [{
  "root": "subpkg",
  "pages": [{
    "path": "goods_detail/goods_detail",
    "style": {}
  }, {
    "path": "goods_list/goods_list",
    "style": {
      "onReachBottomDistance": 150,
      "enablePullDownRefresh": true,
      "backgroundColor": "#F8F8F8"
    }
  }, {
    "path": "search/search",
    "style": {}
  }]
}]

監(jiān)聽頁面的onPullDownRefresh事件處理函數(shù):

// 下拉刷新的事件
onPullDownRefresh() {
  // 1. 重置關鍵數(shù)據(jù)
  this.queryObj.pagenum = 1
  this.total = 0
  this.isloading = false
  this.goodsList = []
  // 2. 重新發(fā)起請求
  this.getGoodsList(() => uni.stopPullDownRefresh())
}

修改getGoodsList函數(shù),接收cb回調函數(shù)并按需進行調用:

// 獲取商品列表數(shù)據(jù)的方法
async getGoodsList(cb) {
  this.isloading = true
  const { data: res } = await uni.$http.get('/api/public/v1/goods/search', this.queryObj)
  this.isloading = false
  // 只要數(shù)據(jù)請求完畢,就立即按需調用 cb 回調函數(shù)
  cb && cb()
  if (res.meta.status !== 200) return uni.$showMsg()
  this.goodsList = [...this.goodsList, ...res.message.goods]
  this.total = res.message.total
}

到此這篇關于Vue uni-app框架實現(xiàn)上拉加載下拉刷新功能的文章就介紹到這了,更多相關Vue uni-app內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • 淺談vue-router 路由傳參的方法

    淺談vue-router 路由傳參的方法

    這篇文章主要介紹了淺談vue-router 路由傳參的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-12-12
  • vue實現(xiàn)圖片上傳功能

    vue實現(xiàn)圖片上傳功能

    這篇文章主要為大家詳細介紹了vue實現(xiàn)圖片上傳功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-05-05
  • vue模仿網易云音樂的單頁面應用

    vue模仿網易云音樂的單頁面應用

    這篇文章主要介紹了vue仿網易云音樂的單頁面應用實例代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-04-04
  • vue實現(xiàn)登錄時圖形驗證碼

    vue實現(xiàn)登錄時圖形驗證碼

    這篇文章主要為大家詳細介紹了vue實現(xiàn)登錄時圖形驗證碼,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • vue2.0項目實現(xiàn)路由跳轉的方法詳解

    vue2.0項目實現(xiàn)路由跳轉的方法詳解

    這篇文章主要介紹了vue2.0項目實現(xiàn)路由跳轉的詳細方法,非常不錯,具有一定的參考借鑒借鑒價值,需要的朋友可以參考下
    2018-06-06
  • Vue數(shù)據(jù)雙向綁定的深入探究

    Vue數(shù)據(jù)雙向綁定的深入探究

    這篇文章主要給大家介紹了關于Vue數(shù)據(jù)雙向綁定的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-11-11
  • 淺談Vue的響應式原理

    淺談Vue的響應式原理

    讓我們來回顧下Vue的介紹,可以發(fā)現(xiàn)Vue 最顯著的一個功能是響應系統(tǒng)。那么它的實現(xiàn)原理有又是如何呢?下面小編和大家來一起學習一下
    2019-05-05
  • 詳解關于element級聯(lián)選擇器數(shù)據(jù)回顯問題

    詳解關于element級聯(lián)選擇器數(shù)據(jù)回顯問題

    這篇文章主要介紹了詳解關于element級聯(lián)選擇器數(shù)據(jù)回顯問題,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-02-02
  • vue中keep-alive組件實現(xiàn)多級嵌套路由的緩存

    vue中keep-alive組件實現(xiàn)多級嵌套路由的緩存

    本文主要介紹了vue中keep-alive組件實現(xiàn)多級嵌套路由的緩存,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Vue使用枚舉類型實現(xiàn)HTML下拉框步驟詳解

    Vue使用枚舉類型實現(xiàn)HTML下拉框步驟詳解

    本文分步驟給大家介紹了Vue使用枚舉類型實現(xiàn)HTML下拉框的相關知識,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-02-02

最新評論