防抖函数放在onclick里面无效,不触发

发布于 2022-09-12 23:58:37 字数 578 浏览 19 评论 0

防抖函数放在onclick里面无效,不触发

fn.apply(this, arguments)不会触发,为什么?

btnGetResumeContainer.onclick = function() {
  debounce(function(){
    getResume(dataResume)
  }, 3000)
)

     
//防抖debounce代码:
function debounce(fn, delay) {
  var timeout = null; // 创建一个标记用来存放定时器的返回值
  return function (e) {
    // 每当用户输入的时候把前一个 setTimeout clear 掉
    if(timer !== null){
      clearTimeout(timeout);
    }
    // 然后又创建一个新的 setTimeout, 这样就能保证interval 间隔内如果时间持续触发,就不会执行 fn 函数
    timeout = setTimeout(() => {
      fn.apply(this, arguments);
    }, delay);
  };
}

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

对不⑦ 2022-09-19 23:58:37
btnGetResumeContainer.onclick = debounce(function(){
    getResume(dataResume)
  }, 3000);

     
//防抖debounce代码:
function debounce(fn, delay) {
  var timer = null; // 创建一个标记用来存放定时器的返回值
  return function (e) {
    // 每当用户输入的时候把前一个 setTimeout clear 掉
    if(timer !== null){
      clearTimeout(timeout);
    }
    // 然后又创建一个新的 setTimeout, 这样就能保证interval 间隔内如果时间持续触发,就不会执行 fn 函数
    timer = setTimeout(() => {
      timer = null;
      fn.apply(this, arguments);
    }, delay);
  };
}
从来不烧饼 2022-09-19 23:58:37
btnGetResumeContainer.onclick = debounce(function(){
    getResume(dataResume)
  }, 3000)
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文