前端开发中遇到的节流与防抖

防抖:简单总结为多次触发事件只执行最后一次

节流:规定时间内只执行一次(每规定时间执行一次,不会被打断)

代码演示:

防抖:

let timerId = null

const eventTrigger = (timeLimit) => {
    //定时器不为空就删除,只执行最后一个定时器
    if( timerId !== null) {
        clearTimeout(timerId) 
    }
    timerId = setTimeout(()=>{
    //这里可以做一些事件处理操作
    console.log("我是防抖")
    },timeLimit) 
}

节流:

let timerId = null
//timeLimit为定时器限制时间
const eventTrigger = (timeLimit) => {
    //定时器不为空就跳出,不执行下一个定时器
    if( timerId !== null) {
        return
    }
    timerId = setTimeout(()=>{
    //这里可以做一些事件处理操作
    console.log("我是节流")
    //事件结束,定时器设置为空
    timerId = null
    },timeLimit) 
}

总结:节流防抖都是为了性能优化,减少请求对后端的压力

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值