Web Worker使用

web worker是什么?

Web Workers 是 HTML5 中的一项技术,它允许你在浏览器中创建多线程 JavaScript 的一种方式。通常,JavaScript 在浏览器中是单线程执行的,这意味着所有的任务都是按顺序执行的,如果有一个任务需要执行很长时间,那么会导致页面变得不响应,用户体验下降。Web Workers 的出现解决了这个问题,它允许你在后台运行 JavaScript 代码,而不会影响到页面的主线程,从而提高了页面的响应性能。

使用场景

  • 复杂的计算任务:例如数学运算、图像处理、视频处理等。
  • 大规模数据处理:对大型数据集进行排序、过滤、搜索等操作时,使用 Web Workers 可以加速这些操作,而不会影响用户界面的响应性能。
  • 后台数据同步和处理:例如电子商务网站中使用 Web Workers 来处理用户的购物车操作。
  • 文件操作:对大型文件进行读取、解析、处理等操作时,例如在前端进行文件上传和处理时,可以使用 Web Workers 来异步处理文件的读取和解析,以及生成文件预览或者进行文件压缩等操作。

如何使用

javascript 复制代码
// 模拟生成大数据
function generateData() {
  var data = [];
  for (var i = 0; i < 10000000; i++) {
    var item = {
      id: i,
      value: Math.random() * 100
    };
    data.push(item);
  }
  return data;
}

// 检测函数执行的时间
function getTime(fn) {
  // 在函数开始处获取开始时间
  const startTime = performance.now();
  fn();
  // 在函数结束处获取结束时间
  const endTime = performance.now();
  // 输出执行时间
  console.log(endTime - startTime);
}

首先来看平常的数据执行

javascript 复制代码
getTime(generateData)  //  283.19999998807907

属于实打实的在浏览器中执行了283ms,但凡数据生成的复杂一些,量多一些,时间都是难以接受的。

来看运用web worker

javascript 复制代码
// worker.js 文件
self.onmessage = function(event) {
  var result = generateData();
  self.postMessage(result);
};
javascript 复制代码
function workersGenerateData(){
  var worker = new Worker('worker.js');
  worker.postMessage('start');
  worker.onmessage = function(event) {
    console.log('Processed');
  };
}
javascript 复制代码
getTime(workersGenerateData) // 0.09999996423721313
相关推荐
Hi_kenyon4 小时前
快速入门VUE与JS(二)--getter函数(取值器)与setter(存值器)
前端·javascript·vue.js
全栈前端老曹4 小时前
【前端路由】React Router 权限路由控制 - 登录验证、私有路由封装、高阶组件实现路由守卫
前端·javascript·react.js·前端框架·react-router·前端路由·权限路由
zhuà!5 小时前
uv-picker在页面初始化时,设置初始值无效
前端·javascript·uv
摸鱼的春哥5 小时前
实战:在 Docker (Windows) 中构建集成 yt-dlp 的“满血版” n8n 自动化工作流
前端·javascript·后端
_Rookie._5 小时前
关于迭代协议:可迭代协议和迭代器协议,生成器函数 生成器对象的理解
javascript·python
测试游记5 小时前
基于 FastGPT 的 LangChain.js + RAG 系统实现
开发语言·前端·javascript·langchain·ecmascript
Van_captain5 小时前
rn_for_openharmony常用组件_Empty空状态
javascript·开源·harmonyos
zhengxianyi5155 小时前
数据大屏-单点登录ruoyi-vue-pro
前端·javascript·vue.js
我想回家种地5 小时前
python期末复习重点
前端·javascript·python
Van_Moonlight5 小时前
RN for OpenHarmony 实战 TodoList 项目:底部 Tab 栏
javascript·开源·harmonyos