通过定义指令方式实现防抖限制,可为需要防抖的按钮添加防抖的指令即可实现按钮的防抖操作限制,使用方式简洁
代码:
// main.js中写入点击防抖方法
const throttle = {
bind: (el, binding) => {
let throttleTime = binding.value // 防抖时间
if (!throttleTime) { // 用户若不设置防抖时间,则默认1s
throttleTime = 1000
}
let timer
let disable = false
el.addEventListener('click', event => {
if (timer) {
clearTimeout(timer)
}
if (!disable) { // 第一次执行(一点击触发当前事件)
disable = true
} else {
event && event.stopImmediatePropagation()
}
timer = setTimeout(() => {
timer = null
disable = false
}, throttleTime)
}, true)
}
}
使用:
// 1. main.js中注册指令
Vue.directive('throttle', throttle);
// 2. 按钮上使用指令
<button v-throttle="2000" @click="">按钮防抖</button>
<el-button v-throttle="2000" @click="">按钮防抖</el-button>