我是在 utils目录下封装 debounce.js :
let timeout = null
function debounce(fn, wait) {
if (timeout !== null) clearTimeout(timeout)
timeout = setTimeout(fn, wait)
}
export default debounce
<template>
<div>
<button @click="clickMe()">点我啊</button>
</div>
</template>
<script>
import debounce from './../../utils/debounce.js'
export default {
data () {
return {
}
},
methods: {
clickMe(){
debounce(() => {
console.log('触发')
}, 2000)
},
}
}
</script>