useDebounceFn 
防抖函数执行。
防抖是一个忙碌的服务员:如果你一直提出请求,你的请求将被忽略,直到你停下来,给他们一些时间思考你最新的请求。
演示 
用法 
ts
import { useDebounceFn, useEventListener } from '@vueuse/core'
const debouncedFn = useDebounceFn(() => {
  // do something
}, 1000)
useEventListener(window, 'resize', debouncedFn)你也可以传入第三个参数,设置最大等待时间,类似于 lodash debounce
ts
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 操作获取函数的返回值。
ts
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` 来捕获拒绝。
ts
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)推荐阅读 
类型声明 
ts
export type UseDebounceFnReturn<T extends FunctionArgs> = PromisifyFn<T>
/**
 * 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.
 *
 * @__NO_SIDE_EFFECTS__
 */
export declare function useDebounceFn<T extends FunctionArgs>(
  fn: T,
  ms?: MaybeRefOrGetter<number>,
  options?: DebounceFilterOptions,
): UseDebounceFnReturn<T>