节流(互斥)和防抖

节流:执行第一次操作,执行完毕后清除

function throttle(fn,delay){
    let valid = true
    return function() {
       if(!valid){
           //休息时间 暂不接客
           return false 
       }
       // 工作时间,执行函数并且在间隔期内把状态位设为无效
        valid = false
        setTimeout(() => {
            fn()
            valid = true;
        }, delay)
    }
}

 

防抖:取消前一次操作,只执行一段时间内的最后一次操作

function debounce(fn,delay){
    let timer = null //借助闭包
    return function() {
        if(timer){
            clearTimeout(timer) 
        }
        timer = setTimeout(fn,delay) // 简化写法
    }
}

 

posted @ 2021-11-09 14:43  Jacky02  阅读(53)  评论(0)    收藏  举报