JS中防抖和节流

简介: JS中防抖和节流

防抖和节流是什么:

防抖和节流是两种控制函数执行频率的技术,主要用于优化事件处理程序的性能。它们的主要区别在于执行时机和执行次数。

防抖(Debounce)是一种在一段时间内无论触发多少次事件,都只执行一次事件处理程序的技术。具体来说,如果在设定的时间段内,事件被重复触发,则会重新计算延迟时间。例如,电梯第一个人进来后,等待15秒。如果过程中又有人进来,15秒等待重新计时,直到15秒后开始运送,这是防抖。

节流(Throttle)则是在一段时间内无论事件触发多么频繁,都只执行一次事件处理程序的技术。如果在设定的时间段内,事件被重复触发,则只会执行第一次触发的事件处理程序。例如,电梯第一个人进来后,15秒后准时运送一次,这是节流。

 

js防抖和节流实现的原理:

防抖和节流的实现主要依赖于定时器技术。防抖的原理是,当事件被触发后,设定一个延迟时间n秒,如果在这段时间内又被触发,则重新计算延迟时间。而节流的原理是,当事件被触发时,设定一个延迟时间n秒执行该事件,如果在这n秒内再次被触发,也不影响事件的执行。

这两种方法都是为了限制函数的执行频次,优化函数触发频率过高导致的响应速度跟不上触发频率的问题。它们可以防止在短时间内频繁触发同一事件而导致的延迟、假死或卡顿的现象。具体来说,防抖是将多次执行变为最后一次执行,节流是将多次执行变成每隔一段时间执行。

如何实现:

防抖函数的实现:

 

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

在这段代码中,我们创建了一个延迟器timer,当事件被触发时清除已有的定时器并设定一个新的。如果在delay时间段内再次触发该事件,则会重新设定一个新的定时器。

节流函数的实现:

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

在这段代码中,我们设定了一个变量previous为上一次执行函数的时间,每次执行函数时都会比较当前时间与previous的差值是否大于设定的delay值。只有在大于delay值的情况下才会执行函数,从而达到控制函数执行频率的目的。

防抖和节流的应用场景:

防抖和节流的主要应用场景包括:

  • 防抖应用:当需要用户最后一次输入完才发送请求时,如搜索框的搜索输入、窗口大小调整resize等,都适合使用防抖技术。这样可以有效防止因为用户频繁输入导致的结果重复渲染。
  • 节流应用:对于一些需要在连续触发事件时,按照一定的时间间隔执行回调的场景,比如滚动加载、鼠标不断点击等,都可以通过节流来实现。这样可以控制函数的执行频率,避免因为事件处理程序执行过于频繁而导致的性能问题。
相关文章
|
7月前
|
前端开发 JavaScript Java
【JavaScript】JavaScript 防抖与节流:以游戏智慧解锁实战奥秘
【JavaScript】JavaScript 防抖与节流:以游戏智慧解锁实战奥秘
75 3
|
4月前
|
前端开发 JavaScript UED
JavaScript防抖和节流的使用及区别
JavaScript防抖和节流的使用及区别
118 57
|
7月前
|
JavaScript 前端开发 UED
深入理解JavaScript中的节流与防抖技术
理解并合理运用节流与防抖技术,可以帮助我们优化事件处理函数的执行频率,从而提升应用的性能和用户体验。这两种技术通过减少不必要的计算和DOM操作,使得Web应用程序能够更加流畅地运行。 通过掌握防抖和节流的实现原理及应用场景,开发者可以更加灵活地编写高效且性能优化的代码,对于面对高频事件处理时尤其重要。在开发中合理选择使用防抖或节流,将直接影响到应用的响应性和效率。
69 1
|
3月前
|
前端开发 JavaScript UED
JavaScript 中的函数防抖与节流详解及实用场景
在前端开发中,处理用户频繁触发的事件,如输入框的输入、按钮点击、窗口调整大小等,常常需要优化性能以减少无效操作。为此,函数防抖(debounce)和函数节流(throttle)是两种常见的性能优化手段。本文将详细介绍两者的区别与实现,并探讨它们的应用场景。
57 1
|
4月前
|
JavaScript 前端开发
js防抖函数返回值问题解决方案
本文介绍了如何在JavaScript中创建一个带有返回值的防抖函数,通过结合Promise来实现。这种防抖函数可以在事件触发一定时间后再执行函数,并能处理异步操作的返回值。文章提供了防抖函数的实现代码和如何在实际项目中使用该防抖函数的示例。
46 1
|
5月前
|
JavaScript 前端开发 UED
JS 防抖与节流
防抖和节流是优化高频事件处理的技术。针对如`scroll`、`resize`等频繁触发的事件,它们能有效减少不必要的回调执行,节省资源。防抖确保在一段时间内仅执行最后一次操作,适用于输入框自动补全等场景;而节流则按固定间隔执行函数,适合拖拽、滚动事件。通过简单的JavaScript实现,可以显著提升应用性能和用户体验。
46 1
JS 防抖与节流
|
8月前
|
JavaScript 前端开发 UED
js的防抖节流
js的防抖节流
44 1
|
8月前
|
JavaScript
JS中防抖和节流的区别是什么
JS中防抖和节流的区别是什么
54 0
|
8月前
|
JavaScript 前端开发 UED
【面试题】面试官:说说你对js中的 防抖 和 节流 的理解
【面试题】面试官:说说你对js中的 防抖 和 节流 的理解
|
8月前
|
测试技术
js_防抖与节流(闭包的使用)
js_防抖与节流(闭包的使用)
55 0