0

0

javascript如何使用Web Workers_如何实现多线程【教程】

夜晨

夜晨

发布时间:2026-01-27 10:40:02

|

253人浏览过

|

来源于php中文网

原创

Web Workers 不能直接操作 DOM,因其运行在独立线程,无法访问 document、window 等主线程对象;所有 UI 交互须通过 postMessage 与主线程通信,且仅支持可序列化数据传输。

javascript如何使用web workers_如何实现多线程【教程】

Web Workers 不能直接操作 DOM

这是最常踩的坑:Worker 脚本运行在独立线程,documentwindowlocalStorage 等主线程专属对象在 Worker 中根本不存在。试图访问 document.getElementById 会直接抛出 ReferenceError: document is not defined

Worker 只能做纯计算、数据处理、网络请求(fetch)、定时器(setTimeout)等不依赖页面环境的任务。所有与 UI 的交互必须通过 postMessage 和主线程通信。

  • 需要渲染或修改元素?→ 主线程接收消息后操作 DOM
  • 需要读取表单值?→ 主线程先读取,再 postMessage 给 Worker
  • 想用 console.log 调试?→ Worker 里可以,但输出在 DevTools 的 “Workers” 标签页,不是默认 Console

创建 Worker 的路径必须是同源且可访问的文件

不能用内联脚本或字符串生成 Worker,必须传入一个 .js 文件 URL:

// ✅ 正确:相对路径(同源)
const worker = new Worker('./math-worker.js');

// ❌ 错误:Blob URL 需额外处理,且不推荐用于简单场景
// ❌ 错误:new Worker('data:text/javascript,...') 不被所有浏览器支持
// ❌ 错误:跨域文件会触发 CORS 报错:'Access to script at ... is blocked'

常见问题:

立即学习Java免费学习笔记(深入)”;

  • 本地双击 HTML 打开(file:// 协议)→ Worker 加载失败,报 SecurityError;必须起本地服务(如 npx serve
  • Vite / Webpack 项目中,Worker 文件需放在 src 下并被正确识别为模块;Vite 推荐用 new Worker(new URL('./worker.js', import.meta.url), { type: 'module' })

主线程和 Worker 之间只能靠 postMessage 传递可序列化数据

postMessage 底层用结构化克隆算法(Structured Clone Algorithm),不支持函数、undefinedSymbolPromiseRegExpDate 对象(注意:Date 实际上会被转成毫秒时间戳,但行为不稳定,建议显式转 .getTime())。

盛世企业网站管理系统1.1.2
盛世企业网站管理系统1.1.2

免费 盛世企业网站管理系统(SnSee)系统完全免费使用,无任何功能模块使用限制,在使用过程中如遇到相关问题可以去官方论坛参与讨论。开源 系统Web代码完全开源,在您使用过程中可以根据自已实际情况加以调整或修改,完全可以满足您的需求。强大且灵活 独创的多语言功能,可以直接在后台自由设定语言版本,其语言版本不限数量,可根据自已需要进行任意设置;系统各模块可在后台自由设置及开启;强大且适用的后台管理支

下载

典型写法:

// 主线程
worker.postMessage({ action: 'calculate', data: [1, 2, 3, 4] });

worker.onmessage = (e) => {
  console.log('结果:', e.data); // e.data 是纯 JSON 数据
};

// Worker 内(math-worker.js)
self.onmessage = (e) => {
  const { action, data } = e.data;
  if (action === 'calculate') {
    const result = data.reduce((a, b) => a + b, 0);
    self.postMessage({ result }); // 只能发 plain object / array / number / string / boolean
  }
};
  • 大数据量传输(如图像像素数组)时,用 transferable 选项避免拷贝: postMessage(data, [data.buffer]),但之后主线程就无法再访问该 ArrayBuffer
  • 不要在 Worker 里反复 postMessage 小量高频数据,容易阻塞通信通道;可批量聚合后再发

Worker 生命周期和错误处理容易被忽略

Worker 实例不会自动销毁,即使任务完成也持续驻留内存。不手动 worker.terminate() 可能导致内存泄漏,尤其在 SPA 中频繁创建 Worker 的场景。

错误捕获必须分开处理:

  • 主线程:监听 worker.onerror,但注意它只捕获 Worker 初始化失败(如脚本 404),不捕获运行时异常
  • Worker 内:用 self.onerror = () => {...}try/catch 包裹逻辑,并主动 postMessage({ error: 'xxx' }) 通知主线程
  • 网络请求失败、JSON.parse 报错等静默失败,必须显式判断和上报

真正复杂的多线程协作(比如多个 Worker 分片处理大数组、结果归并、进度反馈)需要自己设计消息协议和状态机,原生 Worker 提供的只是通信骨架,不是“开箱即用的多线程 API”。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

418

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

535

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

311

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

77

2025.09.10

scripterror怎么解决
scripterror怎么解决

scripterror的解决办法有检查语法、文件路径、检查网络连接、浏览器兼容性、使用try-catch语句、使用开发者工具进行调试、更新浏览器和JavaScript库或寻求专业帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

208

2023.10.18

500error怎么解决
500error怎么解决

500error的解决办法有检查服务器日志、检查代码、检查服务器配置、更新软件版本、重新启动服务、调试代码和寻求帮助等。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

295

2023.10.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

10

2026.01.27

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.2万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.5万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号