Element?UI中v-infinite-scroll無限滾動組件使用詳解
一、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)刷新瀏覽器頁面或者切換項(xià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,這樣同一個項(xiàng)目,如果多處需要滾動分頁,那么這樣代碼就會更加簡潔和方便,下面我粘貼一下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的組件的各個變量是相互獨(dú)立的,值的修改在組件中不會相互影響。(此處不理解可以去學(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)文章
elementUI動態(tài)表單?+?el-select?按要求禁用問題
這篇文章主要介紹了elementUI動態(tài)表單?+?el-select?按要求禁用問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
vue form check 表單驗(yàn)證的實(shí)現(xiàn)代碼
這篇文章主要介紹了vue form check 表單驗(yàn)證的實(shí)現(xiàn)代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-12-12
vue-cli3單頁構(gòu)建大型項(xiàng)目方案
這篇文章主要介紹了vue-cli3單頁構(gòu)建大型項(xiàng)目方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
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的相關(guān)知識,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07

