防抖和节流

防抖和节流都是前端为了控制用户的频繁交互,提供系统性能

防抖(debounce):

定义:当事件持续触发时候,一定时间内没有在触发,该事件只会执行一次,如果一定事件内,时间不断发生,防抖会结束之前的时间,重新开始新的事件,从而重新开始延时。

适用场景:搜索、滚动加载事件

代码:

html 复制代码
// 防抖函数
function debounce(func, wait) {
  let timeout;
  return function() {
    const context = this;
    const args = arguments;
    clearTimeout(timeout);
    timeout = setTimeout(function() {
      func.apply(context, args);
    }, wait);
  };
}



// 防抖示例
const debouncedSearch = debounce(function() {
  console.log('防抖搜索');
}, 500);
window.addEventListener('scroll', debouncedSearch);

节流:

定义:当事件持续触发时候,一定时间内没有在触发,该事件只会执行一次,如果一定时间内,事件不断发生,节流不会管新触发事件,只有等前面事件结束才会触发新的事件。

适用场景:滚动监听、窗口大小改变等

代码:

html 复制代码
// 节流函数
function throttle(func, wait) {
  let timeout;
  return function() {
    const context = this;
    const args = arguments;
    if(!timeout){
        timeout = setTimeout(function() {
          timeout = null;
          func.apply(context, args);
        }, wait);
    }
  };
}



// 防抖示例
const throttledScroll = throttle(function() {
  console.log('节流行为');
}, 500);
window.addEventListener('scroll', throttledScroll );
相关推荐
第七种黄昏3 分钟前
前端面试-箭头函数
前端·面试·职场和发展
Youyzq4 分钟前
前端box-shadow出现兼容性问题如何处理
前端
携欢12 分钟前
PortSwigger靶场之将 XSS 存储到onclick带有尖括号和双引号 HTML 编码以及单引号和反斜杠转义的事件中通关秘籍
前端·html·xss
三小河20 分钟前
工作中的Ai工具汇总
前端
mapbar_front38 分钟前
react项目开发—关于代码架构/规范探讨
前端·react.js
二木一夕1 小时前
Vue 3 的组合式 API和传统选项式 API区别(vue2转vue3,两者差异)
前端
LuckySusu1 小时前
【vue篇】Vue 项目中的静态资源管理:assets vs static 终极指南
前端·vue.js
LuckySusu1 小时前
【vue篇】Vue.delete vs delete:数组删除的“陷阱”与正确姿势
前端·vue.js
LuckySusu1 小时前
【vue篇】Vue 模板编译原理:从 Template 到 DOM 的翻译官
前端·vue.js
小菜摸鱼1 小时前
Node.js + vue3 大文件-切片上传全流程(视频文件)
前端·node.js