防抖和节流

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

防抖(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 );
相关推荐
web13093320398几秒前
前端下载后端文件流,文件可以下载,但是打不开,显示“文件已损坏”的问题分析与解决方案
前端
王小王和他的小伙伴3 分钟前
解决 vue3 中 echarts图表在el-dialog中显示问题
javascript·vue.js·echarts
学前端的小朱7 分钟前
处理字体图标、js、html及其他资源
开发语言·javascript·webpack·html·打包工具
outstanding木槿12 分钟前
react+antd的Table组件编辑单元格
前端·javascript·react.js·前端框架
好名字08211 小时前
前端取Content-Disposition中的filename字段与解码(vue)
前端·javascript·vue.js·前端框架
摇光931 小时前
js高阶-async与事件循环
开发语言·javascript·事件循环·宏任务·微任务
隐形喷火龙1 小时前
element ui--下拉根据拼音首字母过滤
前端·vue.js·ui
m0_748241121 小时前
Selenium之Web元素定位
前端·selenium·测试工具
风无雨1 小时前
react杂乱笔记(一)
前端·笔记·react.js
胡西风_foxww1 小时前
【ES6复习笔记】Class类(15)
javascript·笔记·es6·继承··class·静态成员