input输入框 输入内容后间隔一定时间发送请求(防抖)

我们经常会遇到需要在输入内容后,直接根据输入的关键词获取想要的内容。(即刻的查询)

问题点:若是仅仅利用@input进行输入的检测,那么在输入一段话的过程中,会发送无数个请求,非常浪费。

解决办法:每次输入触发@input后,应该依靠定时器(如0.5秒后)去延后发送请求。

突破点:若没到设定的0.5秒,又再次输入了呢?因此我们需要在设定定时器前,先清空上一次的定时器。

// 输入检测:
desInput() {
    // 上一次的timer还是null,则证明上一次输入设定的时间还没到
    // 直接清除上一次的定时器,重新定时
    if (this.timer !== null) {
        clearTimeout(this.timer)
    };
    this.timer = setTimeout(() => {
        //这里是发送的查询请求
    }, 500)
}

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值