利用JavaScript实现防抖节流函数的示例代码

下面是关于利用JavaScript实现防抖和节流函数的完整攻略。

什么是防抖和节流?

在讲解防抖和节流函数具体实现之前,先简单介绍一下它们的概念。

防抖

防抖是指在事件被触发n秒后再执行回调函数,如果在这n秒内又被触发,则重新计时。通俗地讲,就是在用户不断操作的情况下,只有在用户最后一次操作完毕后一定时间内才会触发事件。

节流

节流是指在一定时间间隔内只执行一次回调函数。通俗地讲,就是在用户不断操作的情况下,如果触发的频率大于一定限定值,就会被忽略掉,只有在限定时间的间隔内,第一次触发会执行一次回调函数,之后如果触发的频率还没有达到限定值则也会被忽略。

防抖函数实现

利用 JavaScript 实现防抖函数的思路很简单,即设置一个计时器,当用户触发事件时,如果计时器存在,则清除计时器并重新计时;如果计时器不存在,则说明需要首次执行回调函数。下面是一个简单的防抖示例代码:

function debounce(func, wait) {
  let timer = null;
  return function() {
    let context = this;
    let args = arguments;
    if (timer) clearTimeout(timer);
    timer = setTimeout(function() {
      func.apply(context, args);
    }, wait);
  }
}

其中,func 为需要执行的函数,wait 为一个计时器延迟的时间(以毫秒为单位)。

使用该防抖函数的示例代码如下:

const btn = document.querySelector('#btn');
btn.addEventListener('click', debounce(handleClick, 1000));

function handleClick() {
  console.log('按钮被点击了');
}

上面的示例代码中,会在按钮被点击后的1秒钟内如果没有其他的点击事件,就会触发 handleClick 函数。

节流函数实现

利用 JavaScript 实现节流函数的思路也很简单,即使用一个标记变量来判断是否已经执行了回调函数,在一定的时间间隔内,只有第一次触发事件时,才会执行回调函数,之后忽略后续的事件触发。下面是一个简单的节流示例代码:

function throttle(func, wait) {
  let canRun = true;
  return function() {
    let context = this;
    let args = arguments;
    if (!canRun) return;
    canRun = false;
    setTimeout(function() {
      func.apply(context, args);
      canRun = true;
    }, wait);
  }
}

其中,func 为需要执行的函数,wait 为一个时间间隔(以毫秒为单位)。

使用该节流函数的示例代码如下:

const btn = document.querySelector('#btn');
btn.addEventListener('click', throttle(handleClick, 1000));

function handleClick() {
  console.log('按钮被点击了');
}

上面的示例代码中,会在按钮被点击后的1秒钟内,只有第一次点击会触发 handleClick 函数,之后的事件触发都会被忽略掉。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:利用JavaScript实现防抖节流函数的示例代码 - Python技术站

(0)
上一篇 2023年6月11日
下一篇 2023年6月11日

相关文章

  • JS数组及对象遍历方法代码汇总

    JS数组及对象遍历方法代码汇总 在 JavaScript 开发中,我们经常需要对数组和对象进行遍历操作。为了方便我们的开发,JavaScript 提供了许多遍历方法。本篇文章将为大家介绍常用的 JS 数组及对象遍历方法,并给出相应的示例说明。 数组遍历方法 1. for 循环遍历数组 for 循环是比较传统且常用的数组遍历方法。它可以遍历数组的所有元素,并且…

    JavaScript 2023年5月27日
    00
  • JavaScript数组 几个常用方法总结

    JavaScript 数组是一种用于存储多个值的数据结构,它提供了各种各样的方法来方便我们对它进行操作。在本篇攻略中,我们将重点总结几个常用的 JavaScript 数组方法,并提供具体示例说明它们的使用方法。 数组方法列表 以下是我们要介绍的 JavaScript 数组方法: push():在数组的末尾添加一个元素,并返回数组的新长度。 pop():移除并…

    JavaScript 2023年5月18日
    00
  • webpack热模块替换(HMR)/热更新的方法

    Webpack热模块替换(HMR)是一种优化开发工作流的技术,可以在运行时修改代码,而无需刷新页面。这样可以提高我们的开发效率和体验。以下是Webpack热模块替换的详细攻略: 什么是Webpack热模块替换(HMR)/ 热更新? 热模块替换(HMR)是Webpack提供的一种能力,可以让我们在应用程序运行的时候,实现对代码的修改。这意味着我们可以在无需刷新…

    JavaScript 2023年6月11日
    00
  • js 格式化时间日期函数小结

    JS 格式化时间日期函数小结 在编写 web 应用程序或者其他应用程序时,日期和时间往往是非常重要的元素。而 JS 提供了许多内置的函数和方法来操作日期和时间,这里提供一些受欢迎的方法,同时会介绍如何使用它们来格式化日期和时间。 定义日期对象 在使用 JS 处理日期和时间时,通常使用内置的 Date 对象。我们可通过以下方式创建一个日期对象: const c…

    JavaScript 2023年5月27日
    00
  • 编写高性能Javascript代码的N条建议

    下面我会详细讲解一些关于编写高性能JavaScript代码的建议和注意事项。 1. 建议使用 let 和 const,避免使用 var 在 ES6 中,let 和 const 关键字用来声明变量,而 var 关键字也仍然存在。但是,相比较而言,let 和 const 会更加高效和安全一些。 let 关键字用来声明可能会被重新赋值的变量。相比 var,let …

    JavaScript 2023年5月27日
    00
  • javascript实现字符串反转的方法

    JavaScript实现字符串反转的方法 在JavaScript中,我们可以使用以下几种方式来实现字符串反转。 1. 利用split()和reverse()方法 使用JavaScript中的split()方法可以将字符串转换为一个字符数组,而数组中可以使用reverse()方法来反转字符数组,最后再使用join()方法将字符数组转成字符串。 function…

    JavaScript 2023年5月28日
    00
  • 使用JS获取当前地理位置方法汇总

    介绍:本文主要介绍使用JavaScript获取当前地理位置的方法,并提供了相关的代码示例,帮助开发人员更快地集成获取地理位置的功能。 HTML5 Geolocation API HTML5 Geolocation API是W3C定制的用于获取用户地理位置信息的标准API,它可以使用纯JavaScript来获取用户的GPS坐标信息,这是一种免费的获取位置的方法…

    JavaScript 2023年6月11日
    00
  • js 中文汉字转Unicode、Unicode转中文汉字、ASCII转换Unicode、Unicode转换ASCII、中文转换&#XX函数代码

    1. js中文汉字转Unicode: 使用以下代码可以将中文汉字转换成Unicode编码: function cnToUnicode (str) { var unicode = ”; for (var i = 0; i < str.length; i++) { var code = str.charCodeAt(i).toString(16); wh…

    JavaScript 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部