Vue中使用防抖與節(jié)流的方法
何為防抖/節(jié)流
首先先說說何為防抖與節(jié)流
防抖(debounce)
防抖就是一段時間內(nèi)會多次觸發(fā)相同的事件,而我們的目的卻只是想讓他們在不觸發(fā)的多久以后再執(zhí)行該事件,例如鼠標移動事件(mousemove)、輸入框變更事件(change)等等,這個時候我們就需要一個方法去控制他,一段時間內(nèi)沒執(zhí)行該事件后,執(zhí)行該事件,即為防抖
節(jié)流(throttle)
節(jié)流就是短時間內(nèi)會多次觸發(fā)相同的事件,而我們的目的卻只是想讓他們既定時間內(nèi)只觸發(fā)一次,例如滾輪事件(scroll)、鼠標點擊事件(click)等等,這個時候我們就需要一個方法去控制他,一段時間(0.5S/1S)之內(nèi)只能觸發(fā)一次事件,即為節(jié)流
防抖(debounce)
// 防抖
export default function debounce(fn, time) {
time = time || 200
// 定時器
let timer = null
return function(...args) {
var _this = this
if (timer) {
clearTimeout(timer)
}
timer = setTimeout(function() {
timer = null
fn.apply(_this, args)
}, time)
}
}
節(jié)流(throttle)
// 節(jié)流
export default function throttle(fn, time) {
let timer = null
time = time || 1000
return function(...args) {
if (timer) {
return
}
const _this = this
timer = setTimeout(() => {
timer = null
}, time)
fn.apply(_this, args)
}
}
頁面使用
直接就用click的點擊速度模擬觸發(fā)事件的頻率了
<el-button @click="clickDebounce">防抖</el-button> <el-button @click="clickThrottle">節(jié)流</el-button>
//引用定義好的JS方法
import debounce from '@/utils/debounce'
import throttle from '@/utils/throttle'
methods: {
clickDebounce: debounce((e) => {
console.log(1)
}, 1000),
clickThrottle: throttle((e) => {
console.log(2)
}, 1000),
}
使用場景
使用場景根據(jù)業(yè)務(wù)需求可以有很多很多 簡單舉兩個例子
防抖(debounce)搜索框自動搜索的時候,可搜索下拉框遠程搜索的時候,用戶在沒輸入完的情況下,防抖可以節(jié)約請求資源。
鼠標移動的時候,鼠標停下來不動再執(zhí)行方法
節(jié)流(throttle)滾動頁面的時候
總結(jié)
本篇文章就到這里了,希望能夠給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
Vue項目全局配置頁面緩存之按需讀取緩存的實現(xiàn)詳解
這篇文章主要給大家介紹了關(guān)于Vue項目全局配置頁面緩存之實現(xiàn)按需讀取緩存的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起看看吧2018-08-08
vue2.x版本中computed和watch的使用及關(guān)聯(lián)和區(qū)別
這篇文章主要介紹了vue2.x版本中computed和watch的使用及關(guān)聯(lián)和區(qū)別,文章圍繞主題展開詳細的內(nèi)容介紹,需要的小伙伴可以參考一下2022-07-07
web面試MVC與MVVM區(qū)別及Vue為什么不完全遵守MVVM解答
這篇文章主要介紹了web面試中常問問題,MVC與MVVM區(qū)別以及Vue為什么不完全遵守MVVM的難點解答,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-09-09
使用vscode格式化文檔無效的解決辦法(vue代碼格式化文檔無效)
這篇文章主要給大家介紹了關(guān)于使用vscode格式化文檔無效的解決辦法,也就是vue代碼格式化文檔無效,這是最近突然遇到的一個問題,這里給大家介紹一下解決的辦法,需要的朋友可以參考下2023-08-08
結(jié)合el-upload組件實現(xiàn)大文件分片上傳功能
Element UI的el-upload上傳組件相信各位小伙伴都已經(jīng)非常熟悉,最近接了一個新需求,要求在el-upload組件基礎(chǔ)上實現(xiàn)分片上傳功能,即小于等于5M文件正常上傳,大于5M文件切成5M每片上傳,那么這個功能怎么實現(xiàn)呢?一起看看吧2022-09-09

