跳到内容

useWebWorker

分类
导出大小
325 B
最后更改
3 周前
相关

简单的 Web Workers 注册和通信。

用法

js
import { useWebWorker } from '@vueuse/core'

const { data, post, terminate, worker } = useWebWorker('/path/to/worker.js')
状态类型描述
dataRef<any>引用通过 worker 接收到的最新数据,可以被监听以响应传入的消息
workerShallowRef<Worker | undefined>WebWorker 实例的引用
方法签名描述
post(message: any, transfer: Transferable[]): void
(message: any, options?: StructuredSerializeOptions | undefined): void
向 worker 线程发送数据。
terminate() => void停止并终止 worker。

类型声明

typescript
type PostMessage = (typeof Worker.prototype)["postMessage"]
export interface UseWebWorkerReturn<Data = any> {
  data: Ref<Data>
  post: PostMessage
  terminate: () => void
  worker: ShallowRef<Worker | undefined>
}
type WorkerFn = (...args: unknown[]) => Worker
/**
 * Simple Web Workers registration and communication.
 *
 * @see https://vueuse.org.cn/useWebWorker
 * @param url
 * @param workerOptions
 * @param options
 */
export declare function useWebWorker<T = any>(
  url: string,
  workerOptions?: WorkerOptions,
  options?: ConfigurableWindow,
): UseWebWorkerReturn<T>
/**
 * Simple Web Workers registration and communication.
 *
 * @see https://vueuse.org.cn/useWebWorker
 * @param worker
 */
export declare function useWebWorker<T = any>(
  worker: Worker | WorkerFn,
): UseWebWorkerReturn<T>

源码

SourceDocs

贡献者

Anthony Fu
Antério Vieira
Anthony Fu
René Hellenes
Yasser Lahbibi
DarknessChaser
Young
karma
Shinigami
Mario Kolli
Shinigami
wheat
Alex Kozack
userquin

更新日志

v12.0.0-beta.1 于 2024/11/21
0a9ed - feat!: 移除 Vue 2 支持,优化 bundles 并清理 (#4349)
v10.2.0 于 2023/6/16
5988f - fix: 添加 web worker transferable 选项 (#3123)
v10.0.0-beta.5 于 2023/4/13
cb644 - refactor!: 移除 isFunctionisString 工具函数

根据 MIT 许可证发布。