JavaScript之防抖(debounce)

106 阅读1分钟
function deBounce(func, delay) {
  let timer = null; //该timer只会执行一次

  return function(...args) {
    if (timer) clearTimeout(timer);
    timer = setTimeout(() => {
      func.apply(this, args);
    }, delay);
  };
}

调用:var xxx = deBounce(refresh,100)

xxx()
第一次调的deBounce,后面所有次调用return回来的那个function,所以定义timer的内容只会执行一次
而ruturn一个函数的好处是显而易见的,因为这样就避免了在全局作用域申明一个变量去保存定时器,不会污染全局作用域

可以用下面这端代码说明timer为什么只会执行一次

 <!DOCTYPE html>
<html lang="en">

<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
  <style>
    #div {
      height: 500px;
      background-color: red;
    }
  </style>
</head>

<body>
  <div id="div">

  </div>
  <script>
    function debounce(func, time) {
      let timer = null
      console.log(1);
      return function(...args) {
        console.log(2);
      }
    }

    var dv = document.querySelector('#div')
    dv.onmousemove = debounce('move', 100)
  </script>
</body>

</html>