Skip to content

node-zendeskDocs


node-zendesk / clients/throttle / export=

Function: export=()

export=(...arguments_): Function

Creates a throttled function that limits the rate of execution of the provided function. The throttled function ensures that the wrapped function is not invoked more frequently than a specified time interval.

Parameters

• ...arguments_: any[]

The arguments for the throttled function. This can include: - fn (Function): The function to be throttled. - options (object, optional): Throttling options. - options.interval (number|string, optional): The time interval in milliseconds between function calls. - options.window (number, default=1): The sliding window duration in which 'limit' number of calls are allowed. - options.limit (number, default=1): The maximum number of function calls allowed in the specified window. - additionalArgs (...any): Additional arguments to be passed to the throttled function.

Returns

Function

  • A throttled function that queues and limits the execution of the original function.

Examples

ts
const throttledLog = throttle(console.log, 1000); // Throttle to at most 1 call per second
throttledLog('Message 1'); // Logs 'Message 1'
throttledLog('Message 2'); // Queues 'Message 2' to be logged after the throttle interval
ts
const throttledFetch = throttle(fetch, { window: 5, limit: 2 }); // Throttle to at most 2 calls in every 5 seconds
throttledFetch('https://api.example.com/data1'); // Fetches data1
throttledFetch('https://api.example.com/data2'); // Fetches data2
throttledFetch('https://api.example.com/data3'); // Queues data3 to be fetched after the throttle interval

Credit: Original inspiration from https://github.com/brianloveswords/throttle-function "Brian J Brennan" <brianloveswords@gmail.com>

Defined in

clients/throttle.d.ts:26

Released under the MIT License.