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>

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

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

猜你喜欢

转载自blog.csdn.net/m0_56344602/article/details/124495869