vue使用@scroll監(jiān)聽滾動事件時,@scroll無效問題的解決方法詳解
本文實例講述了vue使用@scroll監(jiān)聽滾動事件時,@scroll無效問題的解決方法。分享給大家供大家參考,具體如下:
在網(wǎng)上看了一下vue中監(jiān)聽滾動條滾動事件,清一色的使用document.addEventListener('scroll',function(){})
我是在做滾動條滑到底部時,自動加載更多的時候有這個需求。
我認為使用document.addEventListener會破壞vue的統(tǒng)一性,對我這種有輕微代碼強迫癥的人來說,讓我感覺很不爽。而且這種做法,會讓你更加難以判斷是否滑動到底部了,特別是當(dāng)你并不是整頁滾動,而是頁面中擁有一個fixed固定的頭部時。
在.vue的組件中
<template> <div class="body-container" @scroll="scrollEvent"> <ul> <li></li> …… <li></li> </ul> </div> <template>
export default {
name: 'demo',
data () {
return {
msg: '',
}
},
methods: {
scrollEvent(e){
console.log(e)
},
}
}
照上面的寫法,我發(fā)現(xiàn)即使我的li標簽足夠多,撐滿一頁,頁面滾動的時候并不能觸發(fā)到scrollEvent,是什么原因呢?
經(jīng)過仔細思考,猜想應(yīng)該是滾動事件并不是在我<div class="body-container" @scroll="scrollEvent">這個div上觸發(fā)的,因為滾動條并沒有出現(xiàn)在我這個div上。這個div完全被li標簽撐起來了,產(chǎn)生滾動事件的就是document了。
于是做了一個小試驗,定義一個固定高度的div
<div style="height: 300px" @scroll="scrollEvent"> <div style="height: 200px"></div> <div style="height: 200px"></div> <div style="height: 200px"></div> </div>
當(dāng)我在這個300px固定高度的div中滾動的時候,果然觸發(fā)了scrollEvent,問題原因找到了,接下來就是解決了。
只要我能讓<div class="body-container" @scroll="scrollEvent">擁有固定高度,就能觸發(fā)滾動事件了。
但是固定高度怎么給呢,各個廠商的手機屏幕高度都是不一樣的,總不能讓某些手機顯示不完全,或者底部留空白吧。
當(dāng)然后辦法啦!就是吧html,body,.body-container{height:100%}這樣,我的.body-container就能繼承到document的高度了;
還有另一個辦法,讓.body-container使用fixed定位
.body-container{
position: fixed;
top:6rem;
left: 0;
right:0;
bottom: 0;
overflow: auto
}
因為上下左右的位置都固定了,所以div自然也就有了固定高度,此方法適用于頁面有一個固定高度的頭部導(dǎo)航,我項目中有一個6rem高的頭部導(dǎo)航,所以我采用了fixed定位。
接下來就是驗證是否滑到了底部
export default {
name: 'demo',
data () {
return {
msg: '',
}
},
methods: {
scroll(e){
//滾動的像素+容器的高度>可滾動的總高度-100像素
if(e.srcElement.scrollTop+e.srcElement.offsetHeight>e.srcElement.scrollHeight-100){
this.loadMore(); //加載更多
}
},
}
}
這樣就能比較清晰的判斷是否滾動到了底部。但是如果僅僅這樣寫,當(dāng)滾動到底部100px內(nèi)時,會觸發(fā)很多次加載更多,所以我們需要增加一些判斷條件
methods: {
scroll(e){
// !this.moreLoading 沒有在加載狀態(tài),觸發(fā)加載更多時,把this.moreLoading置未true
// !this.noMore 沒有更多的狀態(tài)為false,當(dāng)我們?nèi)〉降臄?shù)據(jù)長度小于1頁的數(shù)量時,就沒有更多了數(shù)據(jù)了,把 this.noMore置為true,這樣就不會觸發(fā)無意義的加載更多了
if(e.srcElement.scrollTop+e.srcElement.offsetHeight>e.srcElement.scrollHeight-100 && !this.moreLoading && !this.noMore){
this.loadMore();
}
},
}
至此,功能完美的實現(xiàn)了,而且沒有使用document.addEventListener破壞vue的完整性,感覺自己棒棒噠!
希望本文所述對大家vue.js程序設(shè)計有所幫助。
相關(guān)文章
vue.js中父組件調(diào)用子組件的內(nèi)部方法示例
這篇文章主要給大家介紹了關(guān)于vue.js中父組件調(diào)用子組件內(nèi)部方法的相關(guān)資料,文中給出來了詳細的示例代碼供大家參考學(xué)習(xí),對大家的學(xué)習(xí)或者工作具有一定的參考價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10
vue使用動態(tài)組件手寫Router View實現(xiàn)示例
這篇文章主要為大家介紹了vue使用動態(tài)組件手寫RouterView實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06
VUE跨域問題Access to XMLHttpRequest at
今天發(fā)現(xiàn)一個錯誤,VUE發(fā)送請求的時候不能請求到正確數(shù)據(jù),VUE跨域問題Access to XMLHttpRequest at,本文就詳細的來介紹一下解決方法,感興趣的可以了解一下2022-05-05
vue項目中在可編輯div光標位置插入內(nèi)容的實現(xiàn)代碼
這篇文章主要介紹了vue項目中在可編輯div光標位置插入內(nèi)容的實現(xiàn)代碼,代碼簡單易懂,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下2020-01-01
簡易Vue評論框架的實現(xiàn)(父組件的實現(xiàn))
本篇文章主要介紹了簡易 Vue 評論框架的實現(xiàn)(父組件的實現(xiàn)),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-01

