Vue3利用watchEffect监听实现防抖

首先在讲防抖之前先了解一下 watchEffect, 官方对watchEffect的解释是立即执行传入的一个函数,同时响应式追踪其依赖,并在其依赖变更时重新运行该函数。

什么意思呢,意思在页面加载之后就立即执行一遍在watchEffect中的数据,如果写在watchEffect中的响应式数据发生改变则会在次触发watchEffect就像下面这样,刚进入页面就调用了一次

既然了解了watchEffect的执行条件,那么如何使用watchEffect实现防抖呢

那么就需要使用watchEffect的参数 onInvalidate

onInvalidate就是用来注册清理失效时的回调

我们首先在外部写一个函数 antiShake

const antiShake =(val:string,time:number) =>{
    return setTimeout(() => {
        console.log(`用户输入:${val}`)
    }, time);
}

然后我们在watchEffect中

watchEffect((onInvalidate)=>{
  const timer =antiShake(keyword.value,500)
  onInvalidate(()=>clearTimeout(timer))
  console.log('watchEffect',keyword.value)
})

运行

 这样就实现了防抖的效果,

好啦,关于watchEffect就简单介绍到这里了 更多的功能可以查看官方文档

响应式计算和侦听 | Vue.js

完整代码

<script lang="ts" setup>
import {ref, watchEffect} from 'vue'
const antiShake =(val:string,time:number) =>{
    return setTimeout(() => {
        console.log(`用户输入:${val}`)
    }, time);
}
const keyword = ref<string>('')
watchEffect((onInvalidate)=>{
  const timer =antiShake(keyword.value,500)
  onInvalidate(()=>clearTimeout(timer))
  console.log('watchEffect',keyword.value)
})
</script>
<template>
<input v-model="keyword" />
</template>

如果你还有什么问题你可以选择↓↓↓

​​​​​​​微信公众号搜索 海海学前端 来了解更多

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

海海呐

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值