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)刷新瀏覽器頁面或者切換項目的時候進(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)文章
elementUI動態(tài)表單?+?el-select?按要求禁用問題
這篇文章主要介紹了elementUI動態(tài)表單?+?el-select?按要求禁用問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10vue form check 表單驗證的實現(xiàn)代碼
這篇文章主要介紹了vue form check 表單驗證的實現(xiàn)代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2018-12-12vue2.0在沒有dev-server.js下的本地數(shù)據(jù)配置方法
這篇文章主要介紹了vue2.0在沒有dev-server.js下的本地數(shù)據(jù)配置方法的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2018-02-02vue-cli3 打包優(yōu)化之 splitchunks詳解
這篇文章主要介紹了vue-cli3 打包優(yōu)化之 splitchunks的相關(guān)知識,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-07-07