粥里有勺糖

vuePress-theme-reco 粥里有勺糖    2018 - 2023
粥里有勺糖 粥里有勺糖

Choose mode

  • dark
  • auto
  • light
关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
author-avatar

粥里有勺糖

285

文章

40

标签

关于我
备战春秋
  • 心得总结
  • 校招考点汇总
  • 面经汇总
  • 复习自查
技术笔记
  • 技术教程
  • 模板工程
  • 源码学习
  • 技术概念
  • 个人作品
  • 学习笔记
计算机基础
  • 算法与数据结构
  • 操作系统
  • 计算机网络
  • 设计模式
  • 剑指offer
大前端
  • javascript
  • vue
  • html
  • css
  • 🌏浏览器专题
  • Web性能优化
  • regexp
  • node
面试
  • 问解
  • javascript
  • css
  • 手撕代码
  • 性能优化
  • 综合问题
  • 面经汇总
  • 小程序
手撕代码
  • 数据结构与算法
  • javascript
  • css
个人站点
  • GitHub (opens new window)
  • 博客园 (opens new window)
  • 掘金 (opens new window)
线上作品
  • 轻取(文件收集) (opens new window)
  • 个人图床 (opens new window)
  • 考勤小程序 (opens new window)
  • 时光恋人 (opens new window)
  • 在线简历生成 (opens new window)
留言板
Github (opens new window)
  • Code

    • 手撕代码
    • 防抖与节流实现
    • 模式串匹配
    • 居中
    • 定时器实现
    • 任意进制转换
    • 二叉树的遍历

防抖与节流实现

vuePress-theme-reco 粥里有勺糖    2018 - 2023

防抖与节流实现

粥里有勺糖 2020-05-03 面试手撕代码

# 防抖与节流实现

# 防抖

对于短时间内连续触发的事件(上面的滚动事件),防抖的含义就是让某个时间期限内,事件处理函数只执行一次

function debounce(fn,delay){
    let timer
    return function(){
        if(timer){
            clearTimeout(timer)
        }
        timer = setTimeout(fn,delay,...arguments)
    }
}
1
2
3
4
5
6
7
8
9

# 节流

如果短时间内大量触发同一事件,那么在函数执行一次之后,该函数在指定的时间期限内不再工作,直至过了这段时间才重新生效

就好比打游戏释放技能后会有CD(冷却时间)

标志位与定时器实现

function throttle(fn, delay) {
    let flag = false
    return function () {
        if (flag) {
            return
        }
        flag = true
        fn.apply(this, arguments)
        setTimeout(() => {
            flag = false
        }, delay)
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13

使用时间戳

function throttle(fn, delay) {
    let now = 0
    return function () {
        if (now + delay > Date.now()) {
            return
        }
        fn.apply(this, arguments)
        now = Date.now()
    }
}
1
2
3
4
5
6
7
8
9
10

# 节流与防抖相结合

解决:操作频繁的场景,每次操作完都等不到debounce的delay就开始了下一次操作

function superThrottle(fn, delay) {
    let start = Date.now(), timer = null
    return function () {
        let end = Date.now()
        let context = this;
        let args = arguments
        if (start + delay > end) {
            if (timer) {
                clearTimeout(timer)
            }
            timer = setTimeout(() => {
                start = end
                fn.apply(context, args)
            }, delay)
        } else {
            start = end
            fn.apply(context, args)
            clearTimeout(timer)
        }
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
Edit this page (opens new window)
Last Updated: 2022/5/15 12:46:34