如何在Vue中实现防抖和节流以避免重复点击或重复上拉导致的重复操作?
- 内容介绍
- 文章标签
- 相关推荐
本文共计269个文字,预计阅读时间需要2分钟。
javascript/** * 防抖函数 * @param {Function} fn - 要执行的函数 * @param {number} [delay=500] - 延迟时间,默认500毫秒 * @returns {Function} - 防抖后的函数 */function debounce(fn, delay=500) { let timer; return function(...args) { clearTimeout(timer); timer=setTimeout(()=> { console.log(fn); }, delay); };}
废话不多说,直接上代码吧!
/** * 函数防抖 (只执行最后一次点击) * @param fn * @param delay * @returns {Function} * @constructor */ export const Debounce = (fn, t) => { let delay = t || 500; let timer; console.log(fn) console.log(typeof fn) return function () { let args = arguments; if(timer){ clearTimeout(timer); } timer = setTimeout(() => { timer = null; fn.apply(this, args); }, delay); } }; /** * 函数节流 * @param fn * @param interval * @returns {Function} * @constructor */ export const Throttle = (fn, t) => { let last; let timer; let interval = t || 500; return function () { let args = arguments; let now = +new Date(); if (last && now - last < interval) { clearTimeout(timer); timer = setTimeout(() => { last = now; fn.apply(this, args); }, interval); } else { last = now; fn.apply(this, args); } } };
用法
... methods:{ getAliyunData:Throttle(function(){ ... },1000), } ...
以上这篇在vue中使用防抖和节流,防止重复点击或重复上拉加载实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。
本文共计269个文字,预计阅读时间需要2分钟。
javascript/** * 防抖函数 * @param {Function} fn - 要执行的函数 * @param {number} [delay=500] - 延迟时间,默认500毫秒 * @returns {Function} - 防抖后的函数 */function debounce(fn, delay=500) { let timer; return function(...args) { clearTimeout(timer); timer=setTimeout(()=> { console.log(fn); }, delay); };}
废话不多说,直接上代码吧!
/** * 函数防抖 (只执行最后一次点击) * @param fn * @param delay * @returns {Function} * @constructor */ export const Debounce = (fn, t) => { let delay = t || 500; let timer; console.log(fn) console.log(typeof fn) return function () { let args = arguments; if(timer){ clearTimeout(timer); } timer = setTimeout(() => { timer = null; fn.apply(this, args); }, delay); } }; /** * 函数节流 * @param fn * @param interval * @returns {Function} * @constructor */ export const Throttle = (fn, t) => { let last; let timer; let interval = t || 500; return function () { let args = arguments; let now = +new Date(); if (last && now - last < interval) { clearTimeout(timer); timer = setTimeout(() => { last = now; fn.apply(this, args); }, interval); } else { last = now; fn.apply(this, args); } } };
用法
... methods:{ getAliyunData:Throttle(function(){ ... },1000), } ...
以上这篇在vue中使用防抖和节流,防止重复点击或重复上拉加载实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持易盾网络。

