vant van-list下拉加載更多onload事件問(wèn)題
vant van-list下拉加載更多onload事件
問(wèn)題描述
van-list編寫下拉加載更多,利用van-list自帶的下拉加載事件@load="onLoad",但是發(fā)現(xiàn)有次數(shù)限制,仍有部分條件下無(wú)法下拉加載更多。
后來(lái)發(fā)現(xiàn)原因,執(zhí)行完,之后finished恢復(fù)false,同時(shí)將當(dāng)前頁(yè)恢復(fù)為1,不寫的話,代碼不會(huì)自己恢復(fù),因?yàn)檫@些參數(shù)是全局變量,所以會(huì)保留最后執(zhí)行之后的結(jié)果。
所以,在代碼執(zhí)行前要做一個(gè)恢復(fù)。細(xì)節(jié)很重要,因?yàn)檫@個(gè)細(xì)節(jié),耽誤了很久時(shí)間。
this.currentPage = 1; //每次走完函數(shù),將當(dāng)前頁(yè)恢復(fù)至1,防止后面累加,導(dǎo)致點(diǎn)擊別的篩選條件時(shí)無(wú)效,返回finished-text this.finished = false; //同樣,也要將finished恢復(fù),否則,執(zhí)行別的篩選條件時(shí),會(huì)顯示finished-text,并且導(dǎo)致明明還有數(shù)據(jù),但是不會(huì)加載出來(lái).
主要代碼如下
<van-list v-model="loading" :finished="finished" finished-text="我是有底線的~" @load="onLoad">//list自帶的下拉刷新事件 <van-row v-for="(item,key) of Array" :key="key" </van-row>//循環(huán),顯示列表 </van-list>
selType(type) {//從前端的點(diǎn)擊事件獲得type this.selectedType = type; console.log(this.selectedType); this.currentPage = 1; //每次走完函數(shù),將當(dāng)前頁(yè)恢復(fù)至1,防止后面累加,導(dǎo)致點(diǎn)擊別的篩選條件時(shí)無(wú)效,返回finished-text this.finished = false; //同樣,也要將finished恢復(fù),否則,執(zhí)行別的篩選條件時(shí),會(huì)顯示finished-text,并且導(dǎo)致明明還有數(shù)據(jù),但是不會(huì)加載出來(lái). this.onLoad(); }, onLoad(){ this.search(); } search() {//調(diào)用查詢的接口 let params = { type: this.selectedType, index: this.currentPage,//頁(yè)數(shù) size: this.pageSize,//每頁(yè)個(gè)數(shù) } .....(接口)(params).then(res => { console.log(res); this.dataTotal = res.total; //進(jìn)行判斷 if(this.dataTotal <= this.pageSize){ this.Array = res.data.list; console.log(this.Array); }else{ this.currentPage++; let arr = res.data.data.list; this.Array = this.Array.concat(arr); }; // 加載狀態(tài)結(jié)束 this.loading = false; // 數(shù)據(jù)全部加載完成 if (this.Array.length >= this.dataTotal) { this.finished = true;//結(jié)束,顯示我也是有底線的 }; }); }
vant van-list的使用及一些坑的解決
第一步
要使用vant組件,安裝好vant,npm i vant -S
第二步
在你要用到的地方j(luò)s中引入,或者在src/main.js里面引入
import Vue from ‘vue‘; import { List } from ‘vant‘; Vue.use(List);
這里我引入的地方是我要用到的js文件中
第三步
在template中引用
第四步
js中重要代碼
data(){ return{ content_list: [], loading: false,//加載狀態(tài) finished: false,//是否加載 count_page: 1,//加載頁(yè)數(shù) count_num: 4//每頁(yè)限制條數(shù) } }, methods:{ list_onload_more: function () { var _this = this; _this.count_page += 1; // 請(qǐng)求數(shù)據(jù) _this.get_course_list(); } ,get_course_list:function(){ var _this = this; var params ={}; params.page = _this.count_page; params.num = _this.count_num; index_rpc.get_collection_course(params,function (data) { if(data.error_code == 0) { var item = data.data || []; _this.count = data.count; if (params.count_page == 1){ _this.content_list = []; } item.forEach(function(val) { _this.content_list.push(val); }) //這里是用于判斷什么時(shí)候所有數(shù)據(jù)加載完畢,然后進(jìn)行是否進(jìn)行加載關(guān)閉 if(_this.count_num * _this.count_page >= _this.count) { _this.finished = true; }else { _this.finished = false; } }else{ _this.count = 0; _this.content_list = []; _this.finished = true; } //最后數(shù)據(jù)加載完后不要忘記將loading改為false _this.loading = false; }) } }
兩個(gè)事情跳轉(zhuǎn):
第五步
解決遇到的坑
這里我講一下我遇到的一些關(guān)于該組件的問(wèn)題解決方法。
首先, onload在加載時(shí)只觸發(fā)一次,頁(yè)面向下滾動(dòng)時(shí),onload并不加載,你可以在獲取數(shù)據(jù)的時(shí)候手動(dòng)在前面加一個(gè)_this.loading = false。
其次,如果數(shù)據(jù)一次全加載完了,說(shuō)明你表格渲染的高度沒(méi)有固定,或者是高度被撐開(kāi)了,所以才會(huì)導(dǎo)致數(shù)據(jù)會(huì)一次加載完畢。設(shè)置100%也無(wú)效,這時(shí)你要設(shè)置高度。
然后如果一直顯示加載中,無(wú)法關(guān)閉,這時(shí)你要在獲取數(shù)據(jù)里面做一個(gè)判斷,判斷數(shù)據(jù)是否已經(jīng)全部獲取,獲取了就給_this.finished = true,即關(guān)閉加載。
最后,就是css樣式問(wèn)題,列表元素使用了float需要使用類名vant-clearfix清除float,否則會(huì)出現(xiàn)請(qǐng)求被多次觸發(fā)的問(wèn)題。
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
前端實(shí)現(xiàn)不同角色登入展示不同頁(yè)面效果實(shí)例
要實(shí)現(xiàn)不同角色登錄跳轉(zhuǎn)不同的前端頁(yè)面,可以在登錄成功后,根據(jù)用戶的角色信息,使用路由跳轉(zhuǎn)到不同的頁(yè)面,這篇文章主要給大家介紹了關(guān)于前端實(shí)現(xiàn)不同角色登入展示不同頁(yè)面效果的相關(guān)資料,需要的朋友可以參考下2024-08-08Vue CLI3基礎(chǔ)學(xué)習(xí)之pages構(gòu)建多頁(yè)應(yīng)用
這篇文章主要給大家介紹了關(guān)于Vue CLI3基礎(chǔ)學(xué)習(xí)之pages構(gòu)建多頁(yè)應(yīng)用的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Vue CLI3具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06Vue v2.5 調(diào)整和更新不完全問(wèn)題
這篇文章主要介紹了Vue v2.5 調(diào)整和更新不完全問(wèn)題的相關(guān)資料,需要的朋友可以參考下2017-10-10Vue解決echart在element的tab切換時(shí)顯示不正確問(wèn)題
這篇文章主要介紹了Vue解決echart在element的tab切換時(shí)顯示不正確問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08vue-element-admin如何設(shè)置默認(rèn)語(yǔ)言
這篇文章主要介紹了vue-element-admin如何設(shè)置默認(rèn)語(yǔ)言,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-04-04