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

溫馨提示×

溫馨提示×

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

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

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

安国市| 芒康县| 西乌珠穆沁旗| 平和县| 宝丰县| 蓝山县| 桂平市| 商丘市| 崇仁县| 尉犁县| 什邡市| 通城县| 义马市| 柯坪县| 广丰县| 青岛市| 恩平市| 永寿县| 剑川县| 奇台县| 西贡区| 松桃| 土默特左旗| 镇平县| 罗定市| 临朐县| 成安县| 绥中县| 裕民县| 明溪县| 新巴尔虎右旗| 遵化市| 原平市| 靖安县| 象山县| 库尔勒市| 将乐县| 酉阳| 浏阳市| 肃宁县| 汶川县|