简述防抖与节流,必懂(含完整模拟实例)

  • 文章看似很长,实则防抖与节流内容类似,理解其一便知其二
  • 代码不多,耐心跟着敲一遍,基本能理解防抖和节流思想

防抖节流对

防抖 节流
概念 连续的事件,只最后一次触发回调 (如:停止滚动滑动条时,触发一次回调) 连续的事件,间隔一段时间执行一次回调
(如:滚动滚动条时,每隔一段事件触发一次回调)
应用场景 避免用户快速点击按钮,持续发送请求
搜索框持续输入
手机号、邮箱验证
鼠标的mousemove、mouseover
滚动加载,加载更多
搜索框联想功能

防抖

一、原理

事件触发n秒后才能再次发起请求

二、需求场景实例

例:用防抖模拟解决输入框多次发起请求问题
在这里插入图片描述

三、实现思路

  • 1、实现原始输入
<input type="text"/>
//js
var int = document.querySelector("input");
    int.oninput = function(){
   
        console.log(this.value)  //模拟业务逻辑
    }
  • 2、若触发事件,给定一个setTimeOut定时器做延迟触发
  • 3、初始化定时器为null
  • 4、每次点击,清除且重置定时器
  • 5、最后一次点击,即n秒后执行业务逻辑
var int = document.querySelector("input");
var time = null;  //初始化定时器
    int.oninput = function(){
   
        if(time != null){
     //判断是否已存在定时器
            clearTimeout(time)  //清空定时器
        }
        time = setTimeout(
  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值