const debounce = (func, duration = 2000) => { let timeout;
return function (...args) { const effect = () => { timeout = null; return func.apply(this, args); };
clearTimeout(timeout); timeout = setTimeout(effect, duration); };};
export default debounce;
Usage
import debounce from 'utils/debounce';
const handler = debounce( () => console.log('I will print after 4 seconds'), 4000,);
Output
data:image/s3,"s3://crabby-images/5cd07/5cd07e36680274f4fd72c1d6c85109fccba1b815" alt="Output for debounce"