javascript的Web Workers是什么_它如何实现多线程?

admin 百科 12
Web Workers 是浏览器提供的后台线程 API,通过独立执行上下文与主线程消息通信实现并发,不阻塞主线程且无法访问 DOM;需用 postMessage 传递可序列化数据,适用于纯计算等任务。

javascript的Web Workers是什么_它如何实现多线程?-第1张图片-佛山资讯网

Web Workers 是浏览器提供的一个 API,让你能在后台线程中运行 JavaScript 代码,**不阻塞主线程**,从而避免页面卡顿。它不是传统意义上的“多线程”(JavaScript 本身仍是单线程),而是通过**独立的执行上下文 + 主线程与工作线程之间的消息通信**,实现并发执行的效果。

Web Workers 的本质:独立的 JS 执行环境

每个 Worker 都运行在自己的全局上下文中(有自己的 selfconsolesetTimeout 等),但**没有 DOM、windowdocument 等浏览器 API**——它不能直接操作页面。Worker 和主线程之间**不能共享内存或变量**,只能靠 postMessage()onmessage 传递可序列化的数据(如对象、数组、字符串,也支持 Transferable 对象如 ArrayBuffer 实现零拷贝)。

如何创建和使用 Worker

基本用法分三步:

  • 写一个单独的 JS 文件(例如 worker.js),里面定义 self.onmessage 处理消息,并用 self.postMessage() 返回结果
  • 在主线程中用 new Worker('worker.js') 创建实例
  • worker.postMessage(data) 发送数据,用 worker.onmessage 接收响应

例如:主线程计算斐波那契数列这种耗时操作,交给 Worker 做,主线程继续响应用户点击或动画,体验更流畅。

标签: javascript java js cookie 浏览器 win red

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~