为了账号安全,请及时绑定邮箱和手机立即绑定

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

标签:
JavaScript

节流和防抖

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

为什么要节流.gif

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

节流(throttle)

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

1. 时间戳版

节流时间戳版.gif

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("距离上次调用的时间差不满足要求哦");
        }
    }
}
复制代码

节流时间戳版执行.gif

2. 定时器版

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

节流定时器版执行.gif

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

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

防抖(debounce)

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

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

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

作者:大帅老猿
链接:https://juejin.cn/post/6962949488646291486
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消