JS防抖和节流,你真的搞清楚了吗?

很多时候,我们都会觉得防抖和节流是一回事,其实不然,他们还是有很大区别的。

首先说防抖,当一个按钮,你拼命点击,我就不处理,等你什么时候消停了,我取你最后一次点击作为有效的,然后请求后台接口,这个就是防抖。

实际开发中,我们直接使用 lodash 的 debounce 函数来实现防抖。

// 例如,下面是一个带有搜索框的页面,并且需要在用户停止输入 500 毫秒后才开始搜索:
function search(keyword) {
  // 根据关键词进行搜索
  console.log(`Searching for '${keyword}'...`)
}

const inputEl = document.getElementById('search-input');

// 创建 debounce 函数,最多每 500 毫秒执行一次 search 函数
const debouncedSearch = _.debounce(search, 500);

// 监听 input 变化,如果有变化则调用 debouncedSearch 函数
// 每当出现输入变化时,我们会将输入内容传递给 `debouncedSearch` 函数,这个函数会将搜索操作延迟 500 毫秒后执行。因此,只有用户停止输入 500 毫秒之后,才会真正执行搜索操作
inputEl.addEventListener('input', (evt) => {
  const keyword = evt.target.value.trim();
  debouncedSearch(keyword);
});

再来说节流,比如我有一个拖拽的div,我希望每当拖拽发生时,要时刻获取div的XY轴的坐标,比如叫做getPosition函数。因为浏览器的运行速度是极快的,当拖拽发生时,就会过于频繁的触发,这样就很浪费性能,也没必要。

于是,我们希望每隔100ms就触发一次,而不是时刻都在触发,这种有节奏的触发,就是节流。

节流函数可以限制一个函数在一定时间范围内最多执行一次。也就是说,如果同一个函数在短时间内多次触发,这个函数只会以固定的频率执行。

实际开发中,我们直接使用 lodash 的 throttle 函数来实现节流。

// 例如,下面是一个点击按钮时,最多每隔 1 秒输出一次 log 的示例:
function log() {
  console.log('Clicked!');
}

const btnEl = document.getElementById('click-button');

// 创建 throttle 函数,最多每 1 秒执行一次 log 函数
const throttledLog = _.throttle(log, 1000);

// 监听 click 事件,如果有点击则调用 throttledLog 函数
// 每当用户点击按钮时,我们会调用 `throttledLog` 函数,这个函数会通过限制函数的执行频率,保证每隔 1 秒钟输出一条日志。即使用户连续点击按钮,也只有第一次点击可以触发函数的执行,后续的点击都会被忽略
btnEl.addEventListener('click', (evt) => {
  throttledLog();
});

所以,防抖和节流看似很像,很多人以为是一回事,其实不然。

原创文章,作者:guozi,如若转载,请注明出处:https://www.sudun.com/ask/90956.html

(0)
guozi's avatarguozi
上一篇 2024年6月7日 下午1:42
下一篇 2024年6月7日 下午1:58

相关推荐

  • 服务器回收厂家有哪些?

    随着网络安全问题的日益突出,人们对于网络安全加速行业也越来越关注。那么,你知道什么是网络安全加速行业吗?它的发展背景是什么?在这个行业中,服务器回收又扮演着怎样的角色?国内又有哪些…

    行业资讯 2024年4月4日
    0
  • 海外服务器租用网

    海外服务器租用网,是近年来备受关注的一个话题。随着互联网的发展,越来越多的企业和个人需要在海外拥有一台服务器来承载他们的网站或应用程序。但是,什么是海外服务器?它与国内服务器有何不…

    行业资讯 2024年4月19日
    0
  • 网站被屏蔽用英文怎么说呢,网址已被屏蔽

    7、举报:如果用户举报本网站的任何违法行为,将会受到有关部门的调查,并可能被屏蔽。因此,网站运营者必须遵守法律,保证其网站内容的合法性。 8. 其他原因:除了上述原因外,网站屏蔽还…

    行业资讯 2024年5月6日
    0
  • 广东话SEO解析及其在网络营销中的作用

    “广东话SEO解析及其在网络营销中的作用”,你是否听过这样一个词语?它是什么意思呢?它又有着怎样的技术特点呢?更重要的是,它在网络营销中扮演着怎样的角色呢?如果你对这些问题感兴趣,…

    行业资讯 2024年3月24日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注