前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >前端面试手写“节流防抖”你不会?用动画带你秒懂!

前端面试手写“节流防抖”你不会?用动画带你秒懂!

作者头像
王图思睿
发布2021-06-16 16:05:18
6230
发布2021-06-16 16:05:18
举报
文章被收录于专栏:膨胀的面包膨胀的面包

节流和防抖

这是前端面试中比较常见的一个问题,可能会让你现场手写。节流和防抖都是用来控制某些函数的调用频率。举个例子,在窗口 resize 的时候,由于可视区变大,我们可能需要向服务器请求更多内容来填充可视区。但可视区变大的过程中,resize 事件会被触发多次...每次触发都去请求一次的话没有必要...这时就需要节流防抖来做控制。

之前也写过一篇文章介绍了 vue 中如何使用防抖和节流,可以结合本文加深理解

https://cloud.tencent.com/developer/article/1835755

代码语言:javascript
复制
function resize(e) {
    console.log("窗口大小改变了");
}
window.addEventListener('resize', resize);

节流( throttle )

当 resize 事件被触发后,指定时间内不允许再次触发,面试时要是遇到手写的话,可能会问到几种实现方式

1、时间戳版

代码语言:javascript
复制
function throttle(func, delay) {
    var last = 0;
    return function () {
        var now = Date.now();
        if (now >= delay + last) {
            func.apply(this, arguments);
            last = now;
        } else {
            console.log("距离上次调用的时间差不满足要求哦");
        }
    }
}

2、定时器版

代码语言:javascript
复制
function throttle(func, delay) {
    var timer = null;
    return function () {
        if (!timer) {
            func.apply(this, arguments);
            timer = setTimeout(() => {
                timer = null;
            }, delay);
        } else {
            console.log("上一个定时器尚未完成");
        }
    }
}

无论上述哪种写法,节流的意思就是函数在一段时间内的多次调用,仅第一次有效。

所以节流就像是一个看门大爷,每一段时间它只会放一个人进去。

防抖( debounce )

防抖和节流不同的地方在于,函数在一段时间内的多次调用,仅使得最后一次调用有效。

代码语言:javascript
复制
function debounce(func, delay) {
    var timeout;
    return function() {
        clearTimeout(timeout);
        timeout = setTimeout(()=>{
            func.apply(this, arguments);
        }, delay);
    }
}

所以防抖就像是 PK 赛里的待定区,下一个待定的人会把上一个待定的人踢出局

via:

听说前端面试手写”节流防抖“你不会?用动画带你秒懂! - V2EX

https://www.v2ex.com/t/777338#reply10

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-05-17,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 节流和防抖
  • 节流( throttle )
  • 防抖( debounce )
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档