Vue.js是當前最流行的前端框架之一。Vue的無疑是其開發效率最高的優點之一,然而我們在面對某些特殊場景時,還需要進行一些優化。而節流就是我們在優化Vue時需要用到的技巧。
筆者曾經在開發Vue項目時遇到一個需求,需要在滾動一個元素時,每過一段時間就打印元素的位置信息。這時就需要節流技巧來實現。
function throttle(fn, interval) {
let last = 0
return function() {
const context = this
const args = arguments
const now = new Date().getTime()
if (now - last >= interval) {
last = now
fn.apply(context, args)
}
}
}
export default {
mounted() {
const el = document.querySelector('.container')
el.addEventListener('scroll', throttle(this.handleScroll, 1000))
},
methods: {
handleScroll() {
const el = document.querySelector('.container')
console.log('scroll position:', el.scrollTop)
}
}
}
如上所示,我們定義了一個throttle函數,接收函數和間隔時間作為參數進行節流。然后在Vue組件的mounted生命周期鉤子函數中監聽所需滾動元素的scroll事件,并在其中調用throttle函數,將處理滾動的函數和每次的間隔時間作為參數。
最后,我們在組件中編寫處理滾動的函數handleScroll,在其中加入需要執行的邏輯即可。而節流函數會確保在規定的間隔時間內只會執行一次handleScroll函數,避免了無謂的性能浪費。
下一篇json報文嵌套