Current Time: 2021-01-14 18:35:07 572
This is a demo showing sort for large array (5 milion numbers) with or w/o WebWorker.
Clock stops when UI blocking happends.
Clock stops when UI blocking happends.
useWebWorkerFn
Run expensive function without blocking the UI, using a simple syntax that makes use of Promise. A port of alewin/useWorker.
Usage
Basic example
import { useWebWorkerFn } from '@vueuse/core'
const { workerFn } = useWebWorkerFn(() => {
// some heavy works to do in web worker
})
With dependencies
import { useWebWorkerFn } from '@vueuse/core'
const { workerFn, workerStatus, workerTerminate } = useWebWorkerFn(
dates => dates.sort(dateFns.compareAsc),
{
timeout: 50000, // 5 seconds
dependencies: [
'https://cdnjs.cloudflare.com/ajax/libs/date-fns/1.30.1/date_fns.js' // dateFns
],
}
)
Web Worker
Before you start using this function, we suggest you read the Web Worker documentation.
API
Parameters
Name | Type | Description |
---|---|---|
fn | Function | The pure function to run with web workers |
options | Object | The object containing the options of the worker |
Options
Name | Type | Default | Description |
---|---|---|---|
timeout | Number | undefined | the number of milliseconds before killing the worker |
dependencies | Array of String | [] | an array that contains the external dependencies needed to run the worker |
Return Value
Name | Type | Description |
---|---|---|
workerFn | Promise | The function that allows you to run fn with web worker |
workerStatus | WebWorkerStatus | The status of workerFn |
workerTerminate | Function | The function that kills the worker |
Credit
This function is a Vue port of https://github.com/alewin/useWorker by Alessio Koci, with the help of @Donskelle to migration.
Type Declarations
export declare type WebWorkerStatus =
| "PENDING"
| "SUCCESS"
| "RUNNING"
| "ERROR"
| "TIMEOUT_EXPIRED"
export interface WebWorkerOptions extends ConfigurableWindow {
timeout?: number
dependencies?: string[]
}
/**
* Run expensive function without blocking the UI, using a simple syntax that makes use of Promise.
*
* @see {@link /useWebWorkerFn}
* @param fn
* @param options
*/
export declare const useWebWorkerFn: <T extends (...fnArgs: any[]) => any>(
fn: T,
{ dependencies, timeout, window }?: WebWorkerOptions
) => {
workerFn: (...fnArgs: Parameters<T>) => Promise<ReturnType<T>>
workerStatus: Ref<WebWorkerStatus>
workerTerminate: (status?: WebWorkerStatus) => void
}