SharedWorker 和 WebWorker 都是浏览器提供的 Web API,用于在后台线程执行脚本,避免阻塞主线程。
它们的主要区别如下:
1. 作用域与通信
WebWorker
每个 Worker 实例仅与创建它的单个页面 / 窗口绑定(一对一)。
页面关闭后,Worker 自动终止。
通过 postMessage() 和事件监听(onmessage)通信,数据通过拷贝传递(非共享内存)。
SharedWorker
可被多个同源页面共享(一对多),需通过端口(port)通信。
即使所有页面关闭,Worker 仍可能继续运行(需手动终止)。
多个页面需先连接到同一 Worker 实例,再通过 port.postMessage() 通信。
2. 生命周期
WebWorker
随创建页面的关闭而销毁,适合短期任务。
SharedWorker
独立于单个页面,需通过 worker.port.close() 或 self.close() 手动终止,适合长期共享任务(如实时数据同步)。
3. 适用场景
WebWorker
单页面的计算密集型任务(如大数组处理、加密运算)。
无需多页面协作的后台工作。
SharedWorker
多标签页共享状态(如聊天室、实时通知)。
跨页面资源缓存(如数据库连接池)。
4. 代码示例对比
WebWorker// 主线程 const worker = new Worker('worker.js'); worker.postMessage('计算'); // worker.js self.onmessage = (e) => { // 执行计算 self.postMessage('结果'); };SharedWorker
// 主线程 const worker = new SharedWorker('shared-worker.js'); worker.port.start(); // 启动端口 worker.port.postMessage('请求数据'); // shared-worker.js self.onconnect = (e) => { const port = e.ports[0]; port.onmessage = (e) => { // 处理请求 port.postMessage('共享数据'); }; };
5. 兼容性
WebWorker:所有现代浏览器支持,IE10+。
SharedWorker:主流浏览器支持(Chrome、Firefox、Safari),但 IE/Edge 不支持。网友回复
python如何将2d平面线图转换成数字2d线稿图?
acejs代码编辑器如何调用openai api实现选择代码修改与代码自动补全?
ace.js如何获取选择文本的开始和结束行数?
如何把qwen code cli或gemini cli的免费调用额度换成http api对外开放接口?
如何限制windows10电脑只能打开指定的程序?
python如何调用ai大模型实现web网页系统的功能测试并生成测试报告?
有没有免费进行web网站ai仿真人测试生成测试报告的mcp服务或api?
Context Engineering到底是啥,有什么用?
如何使用Google veo 3+高斯溅射(Gaussian Splatting)技术生成4d视频?
浏览器中如何实时调用摄像头扫描二维码?