<bdo id='Cyrgt'></bdo><ul id='Cyrgt'></ul>

  • <small id='Cyrgt'></small><noframes id='Cyrgt'>

    <tfoot id='Cyrgt'></tfoot>
      <i id='Cyrgt'><tr id='Cyrgt'><dt id='Cyrgt'><q id='Cyrgt'><span id='Cyrgt'><b id='Cyrgt'><form id='Cyrgt'><ins id='Cyrgt'></ins><ul id='Cyrgt'></ul><sub id='Cyrgt'></sub></form><legend id='Cyrgt'></legend><bdo id='Cyrgt'><pre id='Cyrgt'><center id='Cyrgt'></center></pre></bdo></b><th id='Cyrgt'></th></span></q></dt></tr></i><div id='Cyrgt'><tfoot id='Cyrgt'></tfoot><dl id='Cyrgt'><fieldset id='Cyrgt'></fieldset></dl></div>
      <legend id='Cyrgt'><style id='Cyrgt'><dir id='Cyrgt'><q id='Cyrgt'></q></dir></style></legend>

        一文学会JavaScript如何手写防抖节流

        在本篇文章中,我们将深入探讨JavaScript中的“防抖(debounce)”和“节流(throttle)”的概念,以及如何手写实现它们。以下是详细攻略:

          <tbody id='qFUkJ'></tbody>

          <small id='qFUkJ'></small><noframes id='qFUkJ'>

              <bdo id='qFUkJ'></bdo><ul id='qFUkJ'></ul>
              <tfoot id='qFUkJ'></tfoot>

                  <i id='qFUkJ'><tr id='qFUkJ'><dt id='qFUkJ'><q id='qFUkJ'><span id='qFUkJ'><b id='qFUkJ'><form id='qFUkJ'><ins id='qFUkJ'></ins><ul id='qFUkJ'></ul><sub id='qFUkJ'></sub></form><legend id='qFUkJ'></legend><bdo id='qFUkJ'><pre id='qFUkJ'><center id='qFUkJ'></center></pre></bdo></b><th id='qFUkJ'></th></span></q></dt></tr></i><div id='qFUkJ'><tfoot id='qFUkJ'></tfoot><dl id='qFUkJ'><fieldset id='qFUkJ'></fieldset></dl></div>
                • <legend id='qFUkJ'><style id='qFUkJ'><dir id='qFUkJ'><q id='qFUkJ'></q></dir></style></legend>

                  在本篇文章中,我们将深入探讨JavaScript中的“防抖(debounce)”和“节流(throttle)”的概念,以及如何手写实现它们。以下是详细攻略:

                  什么是防抖和节流

                  在理解如何手写实现防抖和节流之前,需要先了解它们是什么。

                  防抖

                  当需要执行一个函数时,如果该函数需要被频繁地调用,会导致性能问题。防抖可以解决这个问题。防抖的原理是:在调用函数后,设置一个定时器,如果在定时器的时间范围内再次调用该函数,则会清除先前的定时器,并重新设置一个新的定时器。如果在该定时器的时间范围内没有再次调用该函数,则执行该函数。

                  节流

                  与防抖类似,节流也是为了解决频繁调用函数出现性能问题的问题。不同之处在于,节流是在多次调用中只执行一次函数。具体做法是,在每次调用函数前,先比较当前时间与上一次执行时间的时间差,如果时间差超过了规定的时间间隔,则执行该函数并更新执行时间;如果时间差没有超过规定的时间间隔,则不执行该函数。

                  手写实现防抖

                  以下是手写实现防抖的代码:

                  function debounce(fn, delay) {
                    let timer = null;
                    return function () {
                      clearTimeout(timer);
                      timer = setTimeout(() => {
                        fn.apply(this, arguments);
                      }, delay);
                    };
                  }
                  

                  以上代码中,我们定义了一个函数debounce,它接收两个参数:要防抖执行的函数fn和防抖等待执行时间delay。该函数中创建了一个定时器timer,并返回一个闭包函数,在每次调用该闭包函数时,会清除先前的定时器,并重新设置一个新的定时器来延迟执行fn函数。

                  以下是一个使用防抖函数的示例,假设我们想要在通过输入框搜索时避免频繁地向后端发送请求:

                  let input = document.querySelector('#search');
                  input.addEventListener('input', debounce((e) => {
                    // 发送请求给后端
                  }, 500));
                  

                  在以上代码中,我们在输入框上添加了一个事件监听器,该事件监听器使用了debounce函数来延迟500ms执行搜索函数。这样,无论用户输入速度如何,我们都只会在用户停止输入一段时间之后才进行搜索。

                  手写实现节流

                  以下是手写实现节流的代码:

                  function throttle(fn, interval) {
                    let previous = 0;
                    return function () {
                      const current = Date.now();
                      if (current - previous > interval) {
                        fn.apply(this, arguments);
                        previous = current;
                      }
                    };
                  }
                  

                  以上代码中,我们定义了一个函数throttle,它接收两个参数:要节流执行的函数fn和节流执行时间间隔interval。该函数中定义了一个变量previous来记录上一次执行函数的时间,在每次调用该闭包函数时,会比较当前时间与上一次执行时间的时间差,如果时间差超过了规定的时间间隔,则执行该函数并更新执行时间;如果时间差没有超过规定的时间间隔,则不执行该函数。

                  以下是一个使用节流函数的示例,假设我们想要在用户进行窗口滚动时避免频繁地调用函数:

                  window.addEventListener('scroll', throttle(() => {
                    // 处理函数逻辑
                  }, 500));
                  

                  在以上代码中,我们在窗口上添加了一个滚动事件监听器,该事件监听器使用了throttle函数来限制函数调用时间间隔为500ms。这样,即使用户频繁触发滚动事件,我们也只会在指定时间间隔内调用一次函数。

                  结论

                  本文介绍了JavaScript中的“防抖”和“节流”的概念,并分别通过示例详细讲解了如何手写实现它们。在实际开发中,合理使用防抖和节流可以降低函数的调用次数,从而提高程序性能。

                  本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

                  相关文档推荐

                  layui实现图片上传成功后回显点击放大图片功能,html代码部分: !-- html代码--div class="layui-form-item" label class="layui-form-label"上传图片/label div class="layui-input-block" button type="button" class="layui-btn" id="license-auth-letter-
                  Layui实现数据表格中鼠标悬停图片放大离开时恢复原图的效果,最终效果如下图所示: 实现代码如下,在done函数中调用hoverOpenImg方法 var tableIns = window.demoTable = table .render({ elem : '#idTest', id : 'idTest', url : '/postData', //width : 150
                  我们在用到layui时候,需要点击文本输入框调起弹出选择框并选择内容,这个要怎么操作呢?以下两种方法可以参考: 1、点击名称,弹出信息弹框,选择表格中的某一行,实现效果如下: html页面代码 !--计量器具弹出层-- div id="equipment" lay-filter="equipmen
                  https的网站如果引用百度地图,会出现加载不了的问题,这是因为涉及到跨域问题,网站是https的,但是引用百度地图的是http的,这个要怎么操作呢? 比如我引用的地址:http://api.map.baidu.com/api?v=2.0ak=AK显示 后来看了一下,少了一个s=1字段,加一下s=1
                  做小程序项目的时候,客户提了一个功能需求优化,就是长按文字需要复制全部内容,因为有的手机支持全选复制,有的手机不支持全选复制。 通过设置系统剪贴板的内容和获取系统剪贴板的内容实现复制功能 html相关代码: van-field value="{{form.contactPhone}}"
                  由于项目功能需要,要实现对table中的行实现拖拽排序功能,找来找去发现Sortable.js能很好的满足这个需求,而且它还是开源的,于是乎就开始学习使用Sortable.js 特点 轻量级但功能强大 移动列表项时有动画 支持触屏设备和大多数浏览器(IE9及以下除外) 支持
                  <tfoot id='C6Gh6'></tfoot>
                  1. <i id='C6Gh6'><tr id='C6Gh6'><dt id='C6Gh6'><q id='C6Gh6'><span id='C6Gh6'><b id='C6Gh6'><form id='C6Gh6'><ins id='C6Gh6'></ins><ul id='C6Gh6'></ul><sub id='C6Gh6'></sub></form><legend id='C6Gh6'></legend><bdo id='C6Gh6'><pre id='C6Gh6'><center id='C6Gh6'></center></pre></bdo></b><th id='C6Gh6'></th></span></q></dt></tr></i><div id='C6Gh6'><tfoot id='C6Gh6'></tfoot><dl id='C6Gh6'><fieldset id='C6Gh6'></fieldset></dl></div>

                        <bdo id='C6Gh6'></bdo><ul id='C6Gh6'></ul>

                            <legend id='C6Gh6'><style id='C6Gh6'><dir id='C6Gh6'><q id='C6Gh6'></q></dir></style></legend>
                              <tbody id='C6Gh6'></tbody>

                            <small id='C6Gh6'></small><noframes id='C6Gh6'>