useDebounceFn
延迟函数的执行。
防抖动是一个过载的等待者:如果你不停地向他提出请求,你的请求将被忽略,直到你停下来给他一些时间来思考你最新的询问。
演示
用法
js
import { useDebounceFn, useEventListener } from '@vueuse/core'
const debouncedFn = useDebounceFn(() => {
// do something
}, 1000)
useEventListener(window, 'resize', debouncedFn)
你也可以传递第三个参数给它,带有最大等待时间,类似于 lodash debounce
js
import { useDebounceFn, useEventListener } from '@vueuse/core'
// If no invokation after 5000ms due to repeated input,
// the function will be called anyway.
const debouncedFn = useDebounceFn(() => {
// do something
}, 1000, { maxWait: 5000 })
useEventListener(window, 'resize', debouncedFn)
可选地,你可以使用 Promise 操作获取函数的返回值。
js
import { useDebounceFn } from '@vueuse/core'
const debouncedRequest = useDebounceFn(() => 'response', 1000)
debouncedRequest().then((value) => {
console.log(value) // 'response'
})
// or use async/await
async function doRequest() {
const value = await debouncedRequest()
console.log(value) // 'response'
}
由于当开发者不需要返回值时,未处理的拒绝错误非常烦人,因此如果函数默认被取消,Promise 将不会被拒绝。你需要指定选项 rejectOnCancel: true
来捕获拒绝。
js
import { useDebounceFn } from '@vueuse/core'
const debouncedRequest = useDebounceFn(() => 'response', 1000, { rejectOnCancel: true })
debouncedRequest()
.then((value) => {
// do something
})
.catch(() => {
// do something when canceled
})
// calling it again will cancel the previous request and gets rejected
setTimeout(debouncedRequest, 500)
推荐阅读
类型声明
typescript
/**
* Debounce execution of a function.
*
* @see https://vueuse.org.cn/useDebounceFn
* @param fn A function to be executed after delay milliseconds debounced.
* @param ms A zero-or-greater delay in milliseconds. For event callbacks, values around 100 or 250 (or even higher) are most useful.
* @param options Options
*
* @return A new, debounce, function.
*/
export declare function useDebounceFn<T extends FunctionArgs>(
fn: T,
ms?: MaybeRefOrGetter<number>,
options?: DebounceFilterOptions,
): PromisifyFn<T>
源码
贡献者
更新日志
v12.8.0
于 2025/3/5v10.0.0-beta.4
于 2023/4/134d757
- feat(types)!: 将 MaybeComputedRef
重命名为 MaybeRefOrGetter