值得一看
广告
彩虹云商城
广告

热门广告位

JavaScript防抖与节流函数实现

防抖和节流是优化高频事件的两种手段。防抖通过延迟执行,确保事件停止触发后才执行一次回调,适用于搜索输入等场景;节流则保证在指定时间间隔内最多执行一次函数,适合滚动监听等需稳定频率的场景。两者核心区别在于:防抖关注最终状态,节流注重规律执行。根据需求选择可显著提升性能与体验。

javascript防抖与节流函数实现

在处理高频触发事件时,比如窗口缩放、滚动、输入框输入等,直接执行回调会导致性能问题。防抖(Debounce)和节流(Throttle)是两种常用的优化手段,用来控制函数的执行频率。

防抖(Debounce)

防抖的核心思想是:在事件被触发后,设置一个延迟,如果在这个延迟内事件再次被触发,则重新计时。只有当事件停止触发超过指定时间后,才会执行一次回调。

适用于搜索建议、按钮重复点击、窗口resize等场景。

示例实现:

立即学习“Java免费学习笔记(深入)”;

function debounce(func, delay) {
  let timer;
  return function (…args) {
    const context = this;
    clearTimeout(timer);
    timer = setTimeout(() => {
      func.apply(context, args);
    }, delay);
  };
}

使用方式:

const sayHello = () => console.log(“Hello!”);
const debouncedSayHello = debounce(sayHello, 500);
window.addEventListener(‘resize’, debouncedSayHello);

节流(Throttle)

节流的核心思想是:规定一个单位时间,在这个时间内,最多只执行一次函数。无论事件触发多少次,函数都会按照固定间隔执行。

适用于滚动加载、鼠标移动、点击提交等需要稳定执行频率的场景。

示例实现(时间戳方式):

AI抖音

AI抖音

AI抖音,会思考的抖音

AI抖音167

查看详情
AI抖音

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

另一种实现(定时器方式):

function throttle(func, delay) {
  let timer;
  return function (…args) {
    const context = this;
    if (!timer) {
      timer = setTimeout(() => {
        func.apply(context, args);
        timer = null;
      }, delay);
    }
  };
}

使用方式:

const logPosition = () => console.log(window.scrollY);
const throttledLog = throttle(logPosition, 100);
window.addEventListener(‘scroll’, throttledLog);

区别与选择

防抖强调“最后一次有效”,适合事件频繁触发但只需响应最终结果的场景。比如用户打字结束后再发起搜索请求。

节流强调“规律执行”,适合需要持续响应但不能太频繁的场景。比如页面滚动时监听位置更新。

根据实际需求选择合适的方式,能显著提升性能和用户体验。

基本上就这些,理解原理后可以根据项目需要扩展支持立即执行、取消功能等高级特性。

相关标签:

javascript java app win 区别 JavaScript NULL if date const console function 事件 this

大家都在看:

JavaScript设备方向检测
JavaScript手势识别技术
JavaScript PWA开发实战
如何构建一个同构JavaScript应用(SSR)并处理路由和数据同步?
JavaScript字符串解析:利用函数动态替换特定模式
温馨提示: 本文最后更新于2025-10-15 22:40:04,某些文章具有时效性,若有错误或已失效,请在下方留言或联系在线客服
文章版权声明 1 本网站名称: 创客网
2 本站永久网址:https://new.ie310.com
1 本文采用非商业性使用-相同方式共享 4.0 国际许可协议[CC BY-NC-SA]进行授权
2 本站所有内容仅供参考,分享出来是为了可以给大家提供新的思路。
3 互联网转载资源会有一些其他联系方式,请大家不要盲目相信,被骗本站概不负责!
4 本网站只做项目揭秘,无法一对一教学指导,每篇文章内都含项目全套的教程讲解,请仔细阅读。
5 本站分享的所有平台仅供展示,本站不对平台真实性负责,站长建议大家自己根据项目关键词自己选择平台。
6 因为文章发布时间和您阅读文章时间存在时间差,所以有些项目红利期可能已经过了,能不能赚钱需要自己判断。
7 本网站仅做资源分享,不做任何收益保障,创业公司上收费几百上千的项目我免费分享出来的,希望大家可以认真学习。
8 本站所有资料均来自互联网公开分享,并不代表本站立场,如不慎侵犯到您的版权利益,请联系79283999@qq.com删除。

本站资料仅供学习交流使用请勿商业运营,严禁从事违法,侵权等任何非法活动,否则后果自负!
THE END
喜欢就支持一下吧
点赞9赞赏 分享
评论 抢沙发

请登录后发表评论

    暂无评论内容