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

Element?UI中v-infinite-scroll無限滾動組件使用詳解

 更新時間:2023年02月08日 10:29:34   作者:Country?Programmer  
在移動端數(shù)據(jù)的更新中許多方法孕育而生,無限滾輪也是解決的方案一種,Element-ui為vue開發(fā)了一個事件(v-infinite-scroll),下面這篇文章主要給大家介紹了關(guān)于Element?UI中v-infinite-scroll無限滾動組件使用的相關(guān)資料,需要的朋友可以參考下

一、v-infinite-scroll無限滾動組件使用詳解

 1、v-infinite-scroll="load" //load無限滾動加載的方法
 2、infinite-scroll-disabled //是否禁用無限滾動加載
 3、infinite-scroll-delay //節(jié)流時延,單位為ms
 4、infinite-scroll-distance //觸發(fā)加載的距離閾值,單位為px
 5、infinite-scroll-immediate //是否立即執(zhí)行加載方法,以防初始狀態(tài)下內(nèi)容無法撐滿容器。
 //默認(rèn)情況下,infinite-scroll-disabled是false,因此如果組件使用無限滾動加載組件,即使在vue不進(jìn)行加載方法的調(diào)用,組件也會調(diào)用該方法,因此如果需要控制的話,盡量是使用infinite-scroll-disabled屬性來進(jìn)行加載方法是否調(diào)用的控制。

二、組件無限加載原因及解決方式

1、問題:使用無限加載的div沒有設(shè)置高度導(dǎo)致無限加載

解決方案:
<div v-infinite-scroll="load" :infinite-scroll-disabled="isInfiniteScrollDisabled" style="margin-bottom: 20px;height:640px;overflow-y:auto" //style的設(shè)置非常關(guān)鍵,一定要設(shè)置height高度 >

在指令使用的div一定要限定高度(height:xxx; overflow-y:auto)load加載方法將在拉取底部時才會被執(zhí)行。

2、問題:為什么在vue中并沒有在任何生命周期中進(jìn)行l(wèi)oad方法的調(diào)用,直接就加載了方法?

解決方案:使用 :infinite-scroll-disabled="isInfiniteScrollDisabled“屬性來進(jìn)行控制。

3、代碼demo演示

<template>
  <div class="vue-class-name">
    <div
      v-infinite-scroll="load"
      :infinite-scroll-disabled="isInfiniteScrollDisabled"
      style="margin-bottom: 20px;height:640px;overflow-y:auto"
    >
      <div
        v-for="item in dataList"
        :key="item.index"
        style="display: inline-block;margin:0px 10px 10px 0px"
      >
        <span>{{item}}</span>
      </div>
      <el-empty
        description="No Data"
        v-if="dataList.length == 0"
        style="height:650px;overflow-y:auto;text-align:center"
      ></el-empty>
      
      <!-- 這個div一定要放在使用指令的div里面-->
      <div align="center" v-if="dataList.length > 0"> 
        <div class="drawer-footer">
          <span v-if="pullStatus === $enum.STATUS.START">
            Pull up to load more
          </span>
          <span v-if="pullStatus === $enum.STATUS.LOADING">
            loading
            <i class="el-icon-loading"></i>
          </span>
          <span v-if="pullStatus === $enum.STATUS.NODATA">
            no more data
          </span>
        </div>
      </div>
    </div>
  </div>
</template>
<script>
export default {
  name: 'VueName',
  mixins: [],
  components: {},
  props: {},
  data: function() {
    return {
     pullStatus: this.$enum.STATUS.START,
     pageIndex: 1,
     pageSize: 20,
     dataList: [],
     isInfiniteScrollDisabled: false,
    };
  },
  computed: {},
  watch: {
  //事件監(jiān)聽:當(dāng)刷新瀏覽器頁面或者切換項目的時候進(jìn)行方法調(diào)用
    projectSpaceId: function(value, oldValue) {
      this.dataList = [];
      this.pageIndex = 1;
      this.pullStatus = this.$enum.STATUS.START;
      this.getLoadMoreData();
    },
  },
  created() {},
  mounted() {
  //一進(jìn)入頁面進(jìn)行方法調(diào)用
    this.getLoadMoreData();
  },
  methods: {
    getLoadMoreData() {
      if (this.pullStatus !=  this.$enum.STATUS.START) {
       return;
       }
      this.pullStatus = this.$enum.STATUS.LOADING;
      this.isInfiniteScrollDisabled = true;
      let params = {};//請求參數(shù),可省略
      this.getData(params).then(resp => {
        if (data.length < this.pageSize ) {
                this.pullStatus = this.$enum.STATUS.NODATA;
            } else {
                this.pageIndex++;
                this.pullStatus = this.$enum.STATUS.START;
            }
        if (resp.data.length > 0) {
          this.dataList = this.dataList.concat(resp.data);//數(shù)組拼接,得到拼接后的數(shù)據(jù)
        }
        this.isInfiniteScrollDisabled = false;
      });
    },
  },
  beforeDestroy() {
    this.dataList = []; //清空數(shù)組
};
</script>
<style scoped></style>

//常量定義
export const STATUS= {
  START: 0, // 上拉加載
  LOADING: 1, // 加載中
  NODATA: 2, // 沒有更多數(shù)據(jù)
};

三、總結(jié)

當(dāng)然,這個組件還有很多可以優(yōu)化的地方,比如:可以將下面這一段代碼抽成公共組件,使用該組件的地方,只需要傳當(dāng)前的pullStatus狀態(tài)即可。

<div class="drawer-footer">
          <span v-if="pullStatus === $enum.STATUS.START">
            Pull up to load more
          </span>
          <span v-if="pullStatus === $enum.STATUS.LOADING">
            loading
            <i class="el-icon-loading"></i>
          </span>
          <span v-if="pullStatus === $enum.STATUS.NODATA">
            no more data
          </span>
        </div>

同時,也可以封裝成一個mixins,這樣同一個項目,如果多處需要滾動分頁,那么這樣代碼就會更加簡潔和方便,下面我粘貼一下mixins里面的代碼:

/** 
 * 頁面無限滾動加載
*/
export default  {
    name: "infiniteScrollMixins",
    data() {
        return {
            pullStatus: this.$enum.STATUS.START,
            pageIndex: 1,
            pageSize: 20,
        }
    },
    computed:  {},
    created() {},
    methods: {
        loadMoreData() {
            if (this.pullStatus !=  this.$enum.STATUS.START) {
                return;
            }
            this.pullStatus = this.$enum.STATUS.LOADING;
            if(this.getLoadMoreData) {
            //使用該mixins的組件需要定義該方法
                this.getLoadMoreData();
            }
        },

        setPullStatus(data = []) {
            if (data.length < this.pageSize ) {
                this.pullStatus = this.$enum.STATUS.NODATA;
            } else {
                this.pageIndex++;
                this.pullStatus = this.$enum.STATUS.START;
            }
        }
    },
    beforeDestroy() {},
};

如何使用封裝的mixins?

1、導(dǎo)入: import 名稱 from ‘路徑’;

2、聲明: mixins: [mixins名稱],

3、此時mixins中定義的data/methods/computed等,在該組件中都可以直接使用,且多個使用mixins的組件的各個變量是相互獨立的,值的修改在組件中不會相互影響。(此處不理解可以去學(xué)習(xí)一下mixins的相關(guān)文檔)

總結(jié)

到此這篇關(guān)于Element UI中v-infinite-scroll無限滾動組件使用的文章就介紹到這了,更多相關(guān)Element UI v-infinite-scroll無限滾動組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Vue之監(jiān)聽方法案例詳解

    Vue之監(jiān)聽方法案例詳解

    這篇文章主要介紹了Vue之監(jiān)聽方法案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • elementUI動態(tài)表單?+?el-select?按要求禁用問題

    elementUI動態(tài)表單?+?el-select?按要求禁用問題

    這篇文章主要介紹了elementUI動態(tài)表單?+?el-select?按要求禁用問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • Vue3?中的??shallowReactive?詳解

    Vue3?中的??shallowReactive?詳解

    本文深入探討了Vue3中新特性shallowReactive的使用和原理,shallowReactive是創(chuàng)建淺響應(yīng)式對象的API,只對對象的第一層屬性進(jìn)行響應(yīng)式轉(zhuǎn)換,不對嵌套對象處理,有助于性能優(yōu)化和狀態(tài)管理,同時也指出了shallowReactive在使用中的注意事項
    2024-10-10
  • vue中echarts3.0自適應(yīng)的方法

    vue中echarts3.0自適應(yīng)的方法

    這篇文章主要介紹了vue中echarts3.0自適應(yīng),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • vue form check 表單驗證的實現(xiàn)代碼

    vue form check 表單驗證的實現(xiàn)代碼

    這篇文章主要介紹了vue form check 表單驗證的實現(xiàn)代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-12-12
  • vue-cli3單頁構(gòu)建大型項目方案

    vue-cli3單頁構(gòu)建大型項目方案

    這篇文章主要介紹了vue-cli3單頁構(gòu)建大型項目方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • 深入淺出分析vue2和vue3的區(qū)別

    深入淺出分析vue2和vue3的區(qū)別

    這篇文章主要介紹了vue2和vue3的區(qū)別,較為詳細(xì)的分析了vue2與vue3的常見區(qū)別與使用方法,需要的朋友可以參考下
    2023-06-06
  • vue2.0在沒有dev-server.js下的本地數(shù)據(jù)配置方法

    vue2.0在沒有dev-server.js下的本地數(shù)據(jù)配置方法

    這篇文章主要介紹了vue2.0在沒有dev-server.js下的本地數(shù)據(jù)配置方法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2018-02-02
  • vue-cli3 打包優(yōu)化之 splitchunks詳解

    vue-cli3 打包優(yōu)化之 splitchunks詳解

    這篇文章主要介紹了vue-cli3 打包優(yōu)化之 splitchunks的相關(guān)知識,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-07-07
  • 在vue中解決提示警告 for循環(huán)報錯的方法

    在vue中解決提示警告 for循環(huán)報錯的方法

    今天小編就為大家分享一篇在vue中解決提示警告 for循環(huán)報錯的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09

最新評論