跳到主要内容

useWebWorkerFn

分类
导出大小
888 B
上次更改
4 个月前
相关

通过使用简单的 Promise 语法,运行开销大的函数而不会阻塞 UI。这是 alewin/useWorker 的一个移植版本。

演示

当前时间:2025-10-23 06:49:11 812

这是一个演示,展示了使用或不使用 WebWorker 对大型数组(5 百万个数字)进行排序。
当 UI 阻塞发生时,时钟停止。

用法

基本示例

ts
import { 
useWebWorkerFn
} from '@vueuse/core'
const {
workerFn
} =
useWebWorkerFn
(() => {
// some heavy works to do in web worker })

带有依赖项

ts
import { 
useWebWorkerFn
} from '@vueuse/core'
const {
workerFn
,
workerStatus
,
workerTerminate
} =
useWebWorkerFn
(
dates
=>
dates
.sort(dateFns.compareAsc),
{
timeout
: 50000,
dependencies
: [
'https://cdnjs.cloudflare.com/ajax/libs/date-fns/1.30.1/date_fns.js', // dateFns ], }, )

带有本地依赖项

ts
import { 
useWebWorkerFn
} from '@vueuse/core'
const
pow
= (
a
: number) =>
a
*
a
const {
workerFn
,
workerStatus
,
workerTerminate
} =
useWebWorkerFn
(
numbers
=>
pow
(
numbers
),
{
timeout
: 50000,
localDependencies
: [
pow
]
}, )
js
import { useWebWorkerFn } from '@vueuse/core'
const pow = (a) => a * a
const { workerFn, workerStatus, workerTerminate } = useWebWorkerFn(
  (numbers) => pow(numbers),
  {
    timeout: 50000,
    localDependencies: [pow],
  },
)

Web Worker

在开始使用此函数之前,我们建议您阅读 Web Worker 文档。

致谢

此函数是 Alessio Koci 的 https://github.com/alewin/useWorker 的 Vue 移植版本,在 @Donskelle 的帮助下完成迁移。

类型声明

显示类型声明
ts
export type 
WebWorkerStatus
=
| "PENDING" | "SUCCESS" | "RUNNING" | "ERROR" | "TIMEOUT_EXPIRED" export interface UseWebWorkerOptions extends ConfigurableWindow { /** * Number of milliseconds before killing the worker * * @default undefined */
timeout
?: number
/** * An array that contains the external dependencies needed to run the worker */
dependencies
?: string[]
/** * An array that contains the local dependencies needed to run the worker */
localDependencies
?: Function[]
} /** * Run expensive function without blocking the UI, using a simple syntax that makes use of Promise. * * @see https://vueuse.org.cn/useWebWorkerFn * @param fn * @param options */ export declare function
useWebWorkerFn
<
T
extends (...
fnArgs
: any[]) => any>(
fn
:
T
,
options
?: UseWebWorkerOptions,
): {
workerFn
: (...
fnArgs
:
Parameters
<
T
>) =>
Promise
<
ReturnType
<
T
>>
workerStatus
:
ShallowRef
<
WebWorkerStatus
,
WebWorkerStatus
>
workerTerminate
: (
status
?:
WebWorkerStatus
) => void
} export type
UseWebWorkerFnReturn
=
ReturnType
<typeof
useWebWorkerFn
>

来源

源代码演示文档

贡献者

Anthony Fu
Fabian
Anthony Fu
IlyaL
wheat
sibbng
Antério Vieira
SerKo
thefeymesaleng
Luvoy
Hawtim
烽宁
Jelf
不见月
Shinigami
Alex Kozack
Richard Musiol

更新日志

0a9ed - feat!: 放弃对 Vue 2 的支持,优化打包并清理 (#4349)
f4028 - feat: 支持本地函数依赖 (#3899)
v10.7.0
fccf2 - feat: 升级依赖 (#3614)
v10.4.0
34206 - fix(useWebWorker): 阻止错误事件冒泡 (#3141)

根据 MIT 许可证发布。