在Vue.js 2.0中,有一個非常有用的功能叫做“防抖(debounce)”。防抖可以防止在一段時間內多次觸發同一事件,從而減少性能消耗,提高頁面流暢度。
防抖常用于輸入框搜索、滾動加載等需要限制操作頻率的場景。具體原理是通過setTimeout函數延遲執行中間函數,每次事件觸發時清除上一次setTimeout,只有在事件停止觸發后才會執行中間函數。
export default {
data () {
return {
timer: null
}
},
methods: {
search: _.debounce(function (query) {
this.fetchData(query)
}, 500),
fetchData (query) {
// 發送請求
}
}
}
上面的代碼展現了一個使用防抖的搜索功能。在methods中定義一個search方法,每次調用時都會執行防抖函數debounce。debounce接收兩個參數,第一個是需要延遲執行的中間函數,在這里是fetchData;第二個是延遲的時間,這里是500ms。當事件觸發時,先清除上一次的setTimeout,然后重新設置setTimeout延遲執行中間函數,直到事件停止觸發,才會觸發中間函數并發送請求。
通過Vue.js內置的防抖函數,可以方便地實現優化頁面性能的效果。