vant-list上拉加載onload事件觸發(fā)多次問題及解決
vant-list上拉加載onload事件觸發(fā)多次
場景
3個tab頁簽切換時,調(diào)用不同接口,在某一個tab只要翻頁到>=2的情況,當它再點擊到另一個tab的時候,另外一個tab就會連續(xù)調(diào)用兩次查詢接口
(因為它不僅觸發(fā)了created還觸發(fā)了onload事件:且順序為:進入created調(diào)用查詢接口,在.then之前,異步查詢還未返回的時候,又會去觸發(fā)onload事件,在current+=1之后再次進行查詢)
知識點運用:
一、基礎用法
List 組件通過 loading 和 finished 兩個變量控制加載狀態(tài),當組件滾動到底部時,會觸發(fā) load事件并將 loading 設置成 true。
此時可以發(fā)起異步操作并更新數(shù)據(jù),數(shù)據(jù)更新完畢后,將 loading 設置成 false 即可。
若數(shù)據(jù)已全部加載完畢,則直接將 finished 設置成 true 即可。
二、List 的運行機制是什么?
List 會監(jiān)聽瀏覽器的滾動事件并計算列表的位置,當列表底部與可視區(qū)域的距離小于offset時,List會觸發(fā)一次 load 事件。
三、為什么 List 初始化后會立即觸發(fā) load 事件?
List 初始化后會觸發(fā)一次 load事件,用于加載第一屏的數(shù)據(jù),這個特性可以通過immediate-check屬性關閉。
四、為什么會連續(xù)觸發(fā) load 事件?
如果一次請求加載的數(shù)據(jù)條數(shù)較少,導致列表內(nèi)容無法鋪滿當前屏幕,List 會繼續(xù)觸發(fā) load事件,直到內(nèi)容鋪滿屏幕或數(shù)據(jù)全部加載完成。
因此你需要調(diào)整每次獲取的數(shù)據(jù)條數(shù),理想情況下每次請求獲取的數(shù)據(jù)條數(shù)應能夠填滿一屏高度。
五、loading 和 finished 分別是什么含義?
List有以下三種狀態(tài),理解這些狀態(tài)有助于你正確地使用List組件:
- 非加載中,loading為false,此時會根據(jù)列表滾動位置判斷是否觸發(fā)load事件(列表內(nèi)容不足一屏幕時,會直接觸發(fā))
- 加載中,loading為true,表示正在發(fā)送異步請求,此時不會觸發(fā)load事件
- 加載完成,finished為true,此時不會觸發(fā)load事件 在每次請求完畢后,需要手動將loading設置為false,表示加載結束
這次遇到的問題,可以利用第五點,解決方法:
在進入created的發(fā)送請求之前,將this.loading = true , ⇒⇒⇒ (利用:加載中,loading為true,表示正在發(fā)送異步請求,此時不會觸發(fā)load事件),讓系統(tǒng)知道此時正在異步請求數(shù)據(jù),讓它別觸發(fā)onload事件
代碼:
<van-list
v-model="loading" class="van-list-style" :immediate-check="false"
:finished="finished" :finished-text="finishedText"
:error.sync="error" error-text="請求失敗,點擊重新加載"
@load="onLoad">
<div class="list" v-if="dataList.length > 0">
<div class="list-box2" v-for="(item,index) in dataList" :key="index" @click="handleClick(item)">
………………………………………
</div>
</div>
<div v-if="noData" style="margin-top:30%">
<img src="@/common/imgs/no-data.png" alt="" style="width:100%">
</div>
</van-list>
data() {
return {
dataList:[],
current:1,
size:10,
loading: false, // 上拉加載 ??????
finished: false, // 上拉加載完畢
error: false, // 是否展示錯誤
finishedText:"沒有更多了",
noData:false, // 是否展示沒有數(shù)據(jù)的圖片
// offset: 100 // 滾動條與底部距離小于 offset 時觸發(fā)load事件
}
},
created() {
// 調(diào)用列表查詢接口
this.init(this.tab)
},
methods:{
init(val) {
if(val === '1') {
this.createList(1,10)
}
},
//查詢接口
createList(current,size) {
let param = { current:current, size:size }
// 重點?。。。。。。。?!在這里將loading置為true
***this.loading = true;***
createList(param).then(res=>{
let that = this
if(res.status == true) {
//賦值
const dataList = res.body.records
const pages = res.body.pages
// 如果返回數(shù)據(jù)為空
if(dataList == null || dataList.length === 0) {
that.finished = true
that.finishedText = "沒發(fā)現(xiàn)任何東西,去其他地方逛逛吧~"
that.noData = true
return
}
// 加載狀態(tài)結束 可以寫在這里也可以寫在finally里面
that.loading = false;
// 根據(jù)當前頁進行數(shù)據(jù)處理
if(that.current === 1) {
that.dataList = dataList
} else {
that.dataList = that.dataList.concat(dataList)
}
// xxx?。?!最后一頁不足10條的情況 ,這樣寫實際有問題,因為如果是最后一頁為10條的情況,就會第二次去調(diào)用接口
//if(dataList.length < that.size) {
// that.finished = true
//that.finishedText = '沒有更多了';
//}
// 使用這種!! 證明已經(jīng)是最后一頁了
if(that.current = pages) {
that.finished = true
that.finishedText = '沒有更多了';
}
}
})
.catch(err=>{this.error = true; })
.finally(()=>{this.loading = false })
},
// 上拉刷新
onLoad() {
this.current+=1
this.createList(this.current,this.size)
},
}
總結
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Vue的transition-group與Virtual Dom Diff算法的使用
這篇文章主要介紹了Vue的transition-group與Virtual Dom Diff算法的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2019-12-12
vue 中基于html5 drag drap的拖放效果案例分析
本文通過三個案例給大家介紹了vue 中基于html5 drag drap的拖放效果 ,需要的朋友可以參考下2018-11-11
vue用vis插件如何實現(xiàn)網(wǎng)絡拓撲圖
這篇文章主要介紹了vue用vis插件如何實現(xiàn)網(wǎng)絡拓撲圖,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-10-10
VUE2 前端實現(xiàn) 靜態(tài)二級省市聯(lián)動選擇select的示例
下面小編就為大家分享一篇VUE2 前端實現(xiàn) 靜態(tài)二級省市聯(lián)動選擇select的示例。具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02

