Skip to content

refThrottled

Category
Export Size
534 B
Last Changed
4 months ago
Alias
useThrottlethrottledRef
Related

Throttle changing of a ref value.

Demo

Delay is set to 1000ms for this demo.

Throttled:

Times Updated: 0

Trailing: true

Leading: false

Usage

ts
import { 
refThrottled
} from '@vueuse/core'
import {
shallowRef
} from 'vue'
const
input
=
shallowRef
('')
const
throttled
=
refThrottled
(
input
, 1000)

An example with object ref.

js
import { refThrottled } from '@vueuse/core'
import { shallowRef } from 'vue'

const data = shallowRef({
  count: 0,
  name: 'foo',
})
const throttled = refThrottled(data, 1000)

data.value = { count: 1, name: 'foo' }
console.log(throttled.value) // { count: 1, name: 'foo' } (immediate)

data.value = { count: 2, name: 'bar' }
data.value = { count: 3, name: 'baz' }
data.value = { count: 4, name: 'qux' }
console.log(throttled.value) // { count: 1, name: 'foo' } (still first value)

// After 1000ms, next change will be applied
await sleep(1100)
data.value = { count: 5, name: 'final' }
await nextTick()
console.log(throttled.value) // { count: 5, name: 'final' } (updated)

Trailing

If you don't want to watch trailing changes, set 3rd param false (it's true by default):

ts
import { 
refThrottled
} from '@vueuse/core'
import {
shallowRef
} from 'vue'
const
input
=
shallowRef
('')
const
throttled
=
refThrottled
(
input
, 1000, false)

Leading

Allows the callback to be invoked immediately (on the leading edge of the ms timeout). If you don't want this behavior, set the 4th param false (it's true by default):

ts
import { 
refThrottled
} from '@vueuse/core'
import {
shallowRef
} from 'vue'
const
input
=
shallowRef
('')
const
throttled
=
refThrottled
(
input
, 1000,
undefined
, false)

Type Declarations

ts
export type 
RefThrottledReturn
<
T
= any> =
Ref
<
T
>
/** * Throttle execution of a function. Especially useful for rate limiting * execution of handlers on events like resize and scroll. * * @param value Ref value to be watched with throttle effect * @param delay A zero-or-greater delay in milliseconds. For event callbacks, values around 100 or 250 (or even higher) are most useful. * @param trailing if true, update the value again after the delay time is up * @param leading if true, update the value on the leading edge of the ms timeout */ export declare function
refThrottled
<
T
= any>(
value
:
Ref
<
T
>,
delay
?: number,
trailing
?: boolean,
leading
?: boolean,
):
RefThrottledReturn
<
T
>
export {
refThrottled
as
throttledRef
,
refThrottled
as
useThrottle
}

Source

SourceDemoDocs

Contributors

Anthony Fu
Anthony Fu
SerKo
IlyaL
Robin
Thimo Sietsma
IlyaL
Danny Feliz

Changelog

v13.1.0 on
c1d6e - feat(shared): ensure return types exists (#4659)
v12.0.0-beta.1 on
0a9ed - feat!: drop Vue 2 support, optimize bundles and clean up (#4349)

Released under the MIT License.

Build faster with AI
New Masterclass to help you leverage AI in your Vue workflow
Get Early Access