Web Worker多线程编程

Web Worker 解决了什么问题

浏览器 Javascript 是以单线程方式运行的,也就是意味着 JS 执行和 UI 渲染占用同一个主线程,当 Javascript 进行高负载的数据处理或运算时,UI 渲染就很有可能被阻断,浏览器就会出现卡顿,这样很容易降低用户体验。

为此,Javascrip 提供了异步操作,如定时器、ajax、I/O 回调等,但这些异步代码都是运行在主线程上的,如果主线程被阻塞,那么异步代码也就无法执行,不能从根本上解决问题。所以多线程Web worker应运而生,它是 HTML5 标准的一部分,允许创建一个新的子线程,子线程和主线程可以同时允许,且互不干扰。

此外 worker 和主线程之间可以通过postMessageonmessage方法进行双向数据通信

Web Worker 如何使用

示例如下

js 复制代码
/*main.js*/
const worker = new Worker("./js/worker.js");
console.log("🚀 ~ worker:", worker);
worker.postMessage("hello");
worker.onmessage = ({ data }) => {
  console.log("🚀", data);
  for (let i = 0; i < 100; i++) {
    console.log("main:", i);
  }
  // worker.terminate()
};
js 复制代码
/*worker.js*/
addEventListener("message", ({ data }) => {
  console.log(data);
  postMessage("hi");
  for (let i = 0; i < 100; i++) {
    console.log("worker:", i);
  }
});

Web Worker 需要注意的问题

访问限制

woorker 子线程所在的全局对象,与主线程不在同一个上下文环境,所以无法访问到主线程的 window 对象,包括 document 对象,document 对象无法被访问到,但是可以通过 postMessage 来传递数据。

跨域限制

worker 脚本文件必须与主线程脚本同源,这个可以将 worker 脚本文件转换成 Blob 对象,在生成 URL,传给 Worker 的构造函数

应用场景

  • 使用专用线程进行数学运算,比如处理大批量数据、读取用户上传文件、更改 canvas 位图等
  • 高频用户交互
  • 数据的预取
相关推荐
CaoLv7 小时前
无需后端!用 React + WebLLM 把大模型装进浏览器,手撸一个“有脾气”的 AI 机器人 🤖
前端
消防大队VUE支队7 小时前
🗓️ 2262年将有两个春节!作为前端的你,日历控件真的写对了吗?
前端·javascript
鸭蛋超人不会飞7 小时前
axios简易封装,适配H5开发
前端·javascript·vue.js
风止何安啊7 小时前
从 “翻页书” 到 “魔术盒”:React 路由凭啥如此丝滑?
前端·react.js·面试
徐小夕7 小时前
10k Star 的开源 AI 记忆引擎:6 行代码,用图谱+向量打造永不遗忘的 AI
前端·后端·github
前端不太难7 小时前
Vue 项目路由 + Layout 的最佳实践
前端·javascript·vue.js
Jolyne_7 小时前
个人积累的一些前端问题解决方案(理论或实践,持续更新....)
前端
程序员祥云7 小时前
港股证劵 社招 一面
前端·面试
qq_4783775157 小时前
python cut_merge video, convert video2gif, cut gif
java·前端·python
巴拉巴拉~~7 小时前
Flutter 通用列表刷新加载组件 CommonRefreshList:下拉刷新 + 上拉加载 + 状态适配
前端·javascript·flutter