跳到主要内容

useDebounceFn

类别
导出大小
392 B
最后更改
5 天前
相关

延迟函数的执行。

防抖动是一个过载的等待者:如果你不停地向他提出请求,你的请求将被忽略,直到你停下来给他一些时间来思考你最新的询问。

演示

此演示的延迟设置为 1000 毫秒,最大等待时间设置为 5000 毫秒。

按钮点击次数:0

事件处理程序调用次数:0

用法

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>

源码

SourceDemoDocs

贡献者

Anthony Fu
IlyaL
Fernando Fernández
Anthony Fu
vaakian X
azaleta
Joe Maylor
Jakub Freisler
wheat

更新日志

v12.8.0 于 2025/3/5
7432f - feat(types): 弃用 MaybeRefMaybeRefOrGetter,转而使用 Vue 原生的 (#4636)
v10.0.0-beta.4 于 2023/4/13
4d757 - feat(types)!: 将 MaybeComputedRef 重命名为 MaybeRefOrGetter

在 MIT 许可证下发布。