前端面试题系统--防抖和节流

面试过程中多次被问到前端性能优化的防抖和节流,下面做一个总结

目录:

防抖和节流的概念

应用场景

手写代码

 防抖概念

连续触发事件,但在一段事件内只执行最后一次。

例如:设定10毫秒执行,当你触发事件之后,会在10毫秒之后执行,但你在还剩5毫秒的适合又触发了一次事件,这时将从新计时。即在这之后的10毫秒才会执行。

从新开始

节流概念

连续触发事件,但在设定的一段时间内只执行一次函数

例如:设定10毫秒执行,在这10毫秒内触发多次,也只能10毫秒后执行一次

不要打断我

应用场景

防抖:

搜索框搜索输入

文本编辑器实时保存

节流

 高频事件 eg: 快速点击、鼠标滑动、resize事件、scroll事件

下拉加载

视频播放记录时间等

 手撕代码

防抖---定时器

let timer = null 

document.querySelector('.ipt').onkenyuo = function(){

    if(timer !== null){
        clearTimeout(timer)
    }
    
    timer = setTimeout(()=>{
    
        console.log('防抖')
    },10)
}

节流---定时器

let timer = null 

document.querySelector('.ipt').onkenyuo = function(){

    if(timer !== null){
        return
    }
    
    timer = setTimeout(()=>{
    
        console.log('节流')
        timer = null 
    },10)
}

节流---截止日期

//函数节流的实现;
function throttle(fn, delay) {
    let curTime = Date. now( );
    return function() {
    let context = this,
    args = arguments,
    nowTime = Date. now( );
    //如果两次时间间隔超过了指定时间,则执行函数。
    if (nowTime - curTime >= delay) {
        curTime = Date. now( );
        return fn. apply( context, args);
    };
}

  • 8
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值