vant-List-@load事件一直觸發(fā)的解決
vant-List-@load事件一直觸發(fā)
項(xiàng)目場(chǎng)景
今天項(xiàng)目用到vant-List,發(fā)現(xiàn)一直觸發(fā)@load事件。
這是請(qǐng)求的page和pageSize
page: 0, pageSize: 10,
后端測(cè)試數(shù)據(jù)一共21條,但是進(jìn)入頁(yè)面就一下請(qǐng)求了三次,全部加載完數(shù)據(jù)了,這樣就達(dá)不到要求了。
問(wèn)題描述
查看了文檔底下的常見(jiàn)問(wèn)題:
為什么會(huì)連續(xù)觸發(fā) load 事件?
如果一次請(qǐng)求加載的數(shù)據(jù)條數(shù)較少,導(dǎo)致列表內(nèi)容無(wú)法鋪滿當(dāng)前屏幕,List 會(huì)繼續(xù)觸發(fā) load 事件,直到內(nèi)容鋪滿屏幕或數(shù)據(jù)全部加載完成。因此你需要調(diào)整每次獲取的數(shù)據(jù)條數(shù),理想情況下每次請(qǐng)求獲取的數(shù)據(jù)條數(shù)應(yīng)能夠填滿一屏高度。
看到這個(gè)時(shí)候我查看了一下代碼,10條的數(shù)據(jù)量是能夠填滿一屏的,但是還是直接請(qǐng)求完成了。
往下走:
在 html、body 上設(shè)置 overflow 后一直觸發(fā)加載?
如果在 html 和 body 標(biāo)簽上設(shè)置了overflow-x: hidden樣式,會(huì)導(dǎo)致 List 一直觸發(fā)加載。
html,
body {
overflow-x: hidden;
}這個(gè)問(wèn)題的原因是當(dāng)元素設(shè)置了overflow-x: hidden樣式時(shí),該元素的overflow-y會(huì)被瀏覽器設(shè)置為auto,而不是默認(rèn)值visible,導(dǎo)致 List 無(wú)法正確地判斷滾動(dòng)容器。
解決方法是去除該樣式,或者在 html 和 body 標(biāo)簽上添加height: 100%樣式。
原因分析
到這里就找到問(wèn)題的原因了,我習(xí)慣在外層盒子加上min-height: 100vh;overflow-x:hidden;沒(méi)想到會(huì)影響這個(gè)組件,麻了。
解決方案
去除overflow-x: hidden;或?qū)in-height: 100vh;改為height: 100vh;
vant-list onLoad觸發(fā)以及tab切換不再觸發(fā)問(wèn)題
首先 van-list 是首次進(jìn)就會(huì)觸發(fā)加載的,滾動(dòng)條滑倒底部不會(huì)再觸發(fā) 一般是因?yàn)橥獠扛叨任垂潭▽?dǎo)致拿不到滾動(dòng)條位置
<template>
? ? <div class="listClass" ref="listout">
? ? ? ? <van-list v-model="loading" :finished="finished" finished-text="沒(méi)有更多了" @load="onLoad">
? ? ? ? ? ? <div v-for="(item, index) in list" :key="index">{{item}}</div>
? ? ? ? </van-list>
? ? </div>
</template>
<script>
export default {
? ? data() {
? ? ? ? return {
? ? ? ? ? ? // 初始化定義
? ? ? ? ? ? loading: true,
? ? ? ? ? ? finished: false,
? ? ? ? ? ? searchData: {
? ? ? ? ? ? ? ? pageSize: 10,
? ? ? ? ? ? ? ? pageNo: 0
? ? ? ? ? ? },
? ? ? ? ? ? list: []
? ? ? ? }
? ? },
? ? methods: {
? ? ? ? onLoad(){
? ? ? ? ? ? this.searchData.pageNo += 1
? ? ? ? ? ? this.obtainList()
? ? ? ? },
? ? ? ? // 列表
? ? ? ? obtainList () {
? ? ? ? ? ? // 調(diào)用列表接口(此為演示)
? ? ? ? ? ? findList(this.searchData).then(res => {
? ? ? ? ? ? ? ? if (res.data.data && res.data.errcode == 0) {
? ? ? ? ? ? ? ? ? ? if(this.searchData.pageNo == 1){
? ? ? ? ? ? ? ? ? ? ? ? this.list = []
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? res.data.data.result.forEach((v) => {
? ? ? ? ? ? ? ? ? ? ? ? this.list.push(v)
? ? ? ? ? ? ? ? ? ? })
? ? ? ? ? ? ? ? ? ? this.loading = false
? ? ? ? ? ? ? ? ? ? if(this.searchData.pageNo >= res.data.data.totalPage) {
? ? ? ? ? ? ? ? ? ? ? ? this.finished = true
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? }
? ? ? ? ? ? })
? ? ? ? }
? ? }
}
</script>
<style scoped>
.listClass {
? ? width: 100%;
? ? height: 100vh;
? ? overflow-y: auto;
}
</style>tab 切換的時(shí)候 需要重置下loading和finished狀態(tài)
? ? // 切換
? ? activeClick (type) {
? ? ? this.searchData.active = type
? ? ? this.searchData.pageNo = 0
? ? ? this.$refs.listout.scrollTop = 0
? ? ? this.loading = true
? ? ? this.finished = false
? ? ? this.onLoad()
? ? }總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue如何調(diào)用接口請(qǐng)求頭增加參數(shù)
這篇文章主要介紹了Vue如何調(diào)用接口請(qǐng)求頭增加參數(shù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-01-01
Vue2項(xiàng)目中對(duì)百度地圖的封裝使用詳解
近期項(xiàng)目需求相關(guān)地圖限定使用百度地圖,功能比較簡(jiǎn)單,下面這篇文章主要給大家介紹了關(guān)于Vue2項(xiàng)目中對(duì)百度地圖的封裝使用的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-06-06
ant design vue動(dòng)態(tài)循環(huán)生成表單以及自定義校驗(yàn)規(guī)則詳解
這篇文章主要介紹了ant design vue動(dòng)態(tài)循環(huán)生成表單以及自定義校驗(yàn)規(guī)則詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
vue頁(yè)面加載時(shí)的進(jìn)度條功能(實(shí)例代碼)
這篇文章主要介紹了vue頁(yè)面加載時(shí)的進(jìn)度條功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-01-01
利用Vue v-model實(shí)現(xiàn)一個(gè)自定義的表單組件
本篇文章主要介紹了利用Vue v-model實(shí)現(xiàn)一個(gè)自定義的表單組件的相關(guān)知識(shí)。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-04-04
Vue 項(xiàng)目部署到服務(wù)器的問(wèn)題解決方法
本篇文章主要介紹了Vue 項(xiàng)目部署到服務(wù)器的問(wèn)題解決方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-12-12
vue項(xiàng)目如何實(shí)現(xiàn)ip和localhost同時(shí)訪問(wèn)
這篇文章主要介紹了vue項(xiàng)目如何實(shí)現(xiàn)ip和localhost同時(shí)訪問(wèn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10
Vue2.0/3.0雙向數(shù)據(jù)綁定的實(shí)現(xiàn)原理詳解
這篇文章主要給大家介紹了關(guān)于Vue2.0/3.0雙向數(shù)據(jù)綁定的實(shí)現(xiàn)原理,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-04-04

