JS封装节流函数

简介: JS封装节流函数

节流函数是一种常用的优化方法,用于限制一个函数在一定时间内只能执行一次,可以有效避免高频率触发函数执行的问题。下面是一个使用原生JS实现的节流函数及一个例子:

function throttle(func, delay) {
  let timer = null;
  let lastRunTime = 0;
  return function() {
    let context = this;
    let args = arguments;
    let currentTime = Date.now();
    clearTimeout(timer);
    if (currentTime - lastRunTime >= delay) {
      func.apply(context, args);
      lastRunTime = currentTime;
    } else {
      timer = setTimeout(function() {
        func.apply(context, args);
        lastRunTime = Date.now();
      }, delay);
    }
  };
}
// 例子:每隔500ms打印一次当前时间
function printTime() {
  console.log(new Date().toLocaleTimeString());
}
const throttledPrintTime = throttle(printTime, 500);
setInterval(throttledPrintTime, 100);

在上述代码中,throttle函数接受两个参数:func是要节流的函数,delay是限制的时间间隔。返回一个新的函数,在调用新函数时,会根据当前时间判断是否执行func

在例子中,我们定义了一个printTime函数,用于打印当前时间。我们使用throttle函数对printTime进行节流,将节流后的函数赋值给throttledPrintTime

然后,我们使用setInterval每100ms调用一次throttledPrintTime函数。由于throttledPrintTime被节流限制为每500ms执行一次,所以实际上每隔500ms才会打印一次当前时间。

这样,通过节流函数可以有效限制函数的执行频率,避免过多的执行次数。

目录
相关文章
|
1月前
|
JavaScript 前端开发 Java
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
本文介绍了JavaScript中常用的函数和方法,包括通用函数、Global对象函数以及数组相关函数。详细列出了每个函数的参数、返回值及使用说明,并提供了示例代码。文章强调了函数的学习应结合源码和实践,适合JavaScript初学者和进阶开发者参考。
41 2
[JS]同事:这次就算了,下班回去赶紧补补内置函数,再犯肯定被主管骂
|
1月前
|
前端开发 JavaScript 开发者
除了 Generator 函数,还有哪些 JavaScript 异步编程解决方案?
【10月更文挑战第30天】开发者可以根据具体的项目情况选择合适的方式来处理异步操作,以实现高效、可读和易于维护的代码。
|
2月前
|
JavaScript 前端开发
JavaScript 函数语法
JavaScript 函数是使用 `function` 关键词定义的代码块,可在调用时执行特定任务。函数可以无参或带参,参数用于传递值并在函数内部使用。函数调用可在事件触发时进行,如用户点击按钮。JavaScript 对大小写敏感,函数名和关键词必须严格匹配。示例中展示了如何通过不同参数调用函数以生成不同的输出。
|
2月前
|
存储 JavaScript 前端开发
JS函数提升 变量提升
【10月更文挑战第6天】函数提升和变量提升是 JavaScript 语言的重要特性,但它们也可能带来一些困惑和潜在的问题。通过深入理解和掌握它们的原理和表现,开发者可以更好地编写和维护 JavaScript 代码,避免因不了解这些机制而导致的错误和不一致。同时,不断提高对执行上下文等相关概念的认识,将有助于提升对 JavaScript 语言的整体理解和运用能力。
|
2月前
|
前端开发 JavaScript UED
JavaScript 中的函数防抖与节流详解及实用场景
在前端开发中,处理用户频繁触发的事件,如输入框的输入、按钮点击、窗口调整大小等,常常需要优化性能以减少无效操作。为此,函数防抖(debounce)和函数节流(throttle)是两种常见的性能优化手段。本文将详细介绍两者的区别与实现,并探讨它们的应用场景。
44 1
|
2月前
|
JavaScript 前端开发
js教程——函数
js教程——函数
42 4
|
2月前
|
存储 JavaScript 前端开发
js中函数、方法、对象的区别
js中函数、方法、对象的区别
21 2
|
2月前
|
JavaScript 前端开发 Java
【javaScript数组,函数】的基础知识点
【javaScript数组,函数】的基础知识点
27 5
|
2月前
|
JavaScript 前端开发
Node.js 函数
10月更文挑战第5天
24 3
|
2月前
|
前端开发 JavaScript
探索JavaScript函数基础
探索JavaScript函数基础
19 3