Skip to content

useDebounceFn

类别
导出体积
388 B
上次更改
8 minutes ago
相关

延迟执行函数。

延迟是一个被过载的服务员:如果你不停地问他问题,直到你停下来并给他一些时间来考虑你最新的问题,他将会忽略你的请求。

示例

Delay is set to 1000ms and maxWait is set to 5000ms for this demo.

Pending: false

Button clicked: 0

Event handler called: 0

使用方法

ts
import { 
useDebounceFn
,
useEventListener
} from '@vueuse/core'
const
debouncedFn
=
useDebounceFn
(() => {
// 做一些事情 }, 1000)
useEventListener
(
window
, 'resize',
debouncedFn
)

你还可以向它传递第三个参数,表示最大等待时间,类似于 lodash debounce

ts
import { 
useDebounceFn
,
useEventListener
} from '@vueuse/core'
// 如果在重复输入后 5000ms 内没有调用,该函数将被调用。 const
debouncedFn
=
useDebounceFn
(() => {
// 做一些事情 }, 1000, {
maxWait
: 5000 })
useEventListener
(
window
, 'resize',
debouncedFn
)

此外,你可以使用 promise 操作来获取函数的返回值。

ts
import { 
useDebounceFn
} from '@vueuse/core'
const
debouncedFn
=
useDebounceFn
(() => 'response', 1000)
debouncedFn
().
then
((
value
) => {
console
.
log
(
value
) // 'response'
}) // 或者使用 async/await async function
doRequest
() {
const
value
= await
debouncedFn
()
console
.
log
(
value
) // 'response'
}

由于未处理的拒绝错误在开发者不需要返回值时相当烦人,promise 在默认情况下如果函数被取消,则不会被拒绝。你需要指定选项 rejectOnCancel: true 来捕获拒绝。

ts
import { 
useDebounceFn
} from '@vueuse/core'
const
debouncedFn
=
useDebounceFn
(() => 'response', 1000, {
rejectOnCancel
: true })
debouncedFn
()
.
then
((
value
) => {
// 做一些事情 }) .
catch
(() => {
// 在被取消时做一些事情 }) // calling it again will cancel the previous request and gets rejected
setTimeout
(
debouncedFn
, 500)

取消

您可以通过调用 cancel 方法来取消任何待执行任务。

ts
import { 
useDebounceFn
} from '@vueuse/core'
const
debouncedFn
=
useDebounceFn
(() => {
// do something }, 1000)
debouncedFn
()
// Cancel the pending execution before it runs
debouncedFn
.
cancel
()

当你需要防止防抖函数执行时,这很有用,例如在组件卸载时,或当用户输入切换上下文时。

待处理状态

你可以使用 isPending ref 检查是否存在待执行的操作。

ts
import { 
useDebounceFn
} from '@vueuse/core'
const
debouncedFn
=
useDebounceFn
(() => {
// do something }, 1000)
debouncedFn
()
console
.
log
(
debouncedFn
.
isPending
.
value
) // true
// After debounce time elapses or cancel is called
console
.
log
(
debouncedFn
.
isPending
.
value
) // false

这对于在等待防抖函数执行时显示加载指示器或禁用界面元素很有用。

刷新

你可以使用 flush 方法立即执行待处理的调用。

ts
import { 
useDebounceFn
} from '@vueuse/core'
const
debouncedFn
=
useDebounceFn
(() => {
// do something }, 1000)
debouncedFn
()
// Execute the pending invocation immediately instead of waiting
debouncedFn
.
flush
()

当你需要确保防抖函数立即执行时,这很有用,例如在离开页面或提交表单之前。

推荐阅读

类型声明

ts
export type 
UseDebounceFnReturn
<
T
extends
FunctionArgs
> =
CancelablePromisifyFn
<
T
>
/** * 延迟执行函数。 * * @see https://vueuse.org/useDebounceFn * @param fn 要在延迟毫秒后执行的函数。 * @param ms 毫秒为单位的延迟时间,必须为零或更大。对于事件回调,最有用的值大约为 100 或 250(甚至更高)。 * @param options 选项 * * @return A new, debounced, function with isPending, cancel, and flush properties. */ export declare function
useDebounceFn
<
T
extends
FunctionArgs
>(
fn
:
T
,
ms
?:
MaybeRefOrGetter
<number>,
options
?:
DebounceFilterOptions
,
):
UseDebounceFnReturn
<
T
>

源码

源码演示文档

贡献者

Anthony Fu
ikxin
SerKo
Pierre Côté
Bruno Kalthoff
Robin
Thimo Sietsma
IlyaL
Fernando Fernández
Anthony Fu
vaakian X
azaleta
Joe Maylor
Jakub Freisler
wheat

更新日志

Pending for release...
4aa18 - feat: add flush and isPending to filter system (#5259)
d32f8 - refactor: add @__NO_SIDE_EFFECTS__ annotations to all pure functions (#4907)
c1d6e - feat(shared): ensure return types exists (#4659)
7432f - feat(types): deprecate MaybeRef and MaybeRefOrGetter in favor of Vue's native (#4636)