亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

Vant-list上拉加載及下拉刷新問題怎么解決

發布時間:2022-04-25 16:21:51 來源:億速云 閱讀:2477 作者:iii 欄目:開發技術

本篇內容介紹了“Vant-list上拉加載及下拉刷新問題怎么解決”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!

Vant-list 上拉加載及下拉刷新

第一步引入

import { Notify, Dialog, Image, List, PullRefresh } from 'vant'
import Vue from 'vue'
Vue.use(Image).use(List).use(PullRefresh)

第二步

<van-pull-refresh v-model="refreshing" @refresh="onRefresh">
      <van-list v-model="loading" :finished="finished" finished-text="沒有更多了" @load="onLoad">
          <!-- 這里根據自己需要展示數據 -->
       </van-list>
    </van-pull-refresh>

第三步

 data () {
    return {
      productList: [], //異步查詢數據
      loading: false, //自定義底部加載中提示
      finished: false,//自定義加載完成后的提示文案
      refreshing: false,//清空列表數據
      pageNo: 0 //當前頁碼
    }
  }

第四步

  methods: {
    onLoad () {
      this.pageNo++
      setTimeout(() => {
        if (this.refreshing) {
          this.productList = []
          this.refreshing = false
        }
        this.loading = false
        const shopId = this.$store.state.user.shopId
        //這里是ajax請求  根據自己業務需求
        pageList({ shopId: shopId, pageNo: this.pageNo, pageSize: 2 }).then(res => {
          if (this.validResp(res)) {
            this.total = res.data.pageNo
            this.loading = true
            this.productList.push(...res.data.dataList)
          }
          if (this.productList.length >= parseInt(res.data.pageNo)) {
            this.finished = true
          }
        })
      }, 1000)
    },
    onRefresh () {
      this.finished = false
      this.loading = true
      this.pageNo = 0
      this.onLoad()
    }
    }

vant下拉刷新與上拉加載一起使用問題

下拉刷新觸發兩次 list與pull

//下拉刷新
 onRefresh() {
                this.list = [];
                this.curPage = 1;
                this.finished = true;
                this.getData();
  },
getData() {
                this.isLoading = false;
                getList({
                    curPage: this.curPage,
                    pageSize: this.pageSize
                }).then((res) => {
 
                    this.listLoading = false;
 
                    if (res.code == 200) {
                        this.list = this.list.concat(res.data.list);
                        this.curPage = res.data.nextPage;
                        if (this.list.length >= res.data.total) {
                            this.finished = true;
                        }else {
                            this.finished = false;
                        }
                    }
                })
            },

原因是在于下拉刷新的時候觸發了上拉加載,所以執行了兩次

解決方法是

先將list組價的finished=true,數據加載完了在判斷該值應該是true還是false,這樣可以避免在下拉刷新的時候觸發上拉加載。

Vant-list上拉加載及下拉刷新問題怎么解決

“Vant-list上拉加載及下拉刷新問題怎么解決”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!

向AI問一下細節

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

AI

柳林县| 咸阳市| 禄劝| 顺平县| 库尔勒市| 广州市| 太谷县| 德阳市| 苍南县| 宣汉县| 西贡区| 乌兰察布市| 长丰县| 安庆市| 聊城市| 万州区| 朝阳区| 上虞市| 崇仁县| 龙口市| 江永县| 灌阳县| 时尚| 凉城县| 东乌珠穆沁旗| 年辖:市辖区| 郁南县| 定安县| 攀枝花市| 宜丰县| 樟树市| 蕉岭县| 彭州市| 阳谷县| 介休市| 体育| 虞城县| 平陆县| 武鸣县| 嘉义县| 山西省|