首页 > 其他分享 >vue 中优雅使用 web worker

vue 中优雅使用 web worker

时间:2024-12-12 10:31:48浏览次数:5  
标签:web vue const Worker worker loader result js

众所周知,JavaScript 是单线程的(帮助理解单线程)。一些复杂而又耗时的操作,势必会阻塞页面的渲染/交互,影响用户体验。web worker 允许开发者为页面额外开启一个线程,用来处理复杂而耗时的操作,不会阻塞主线程,从而达到优化用户体验的目的。

首先,我们来看一下 worker 构造函数的使用。

​
/**
 * url: js 文件路径
 * options: 配置信息
 */
const worker = new Worker(url, options)

​

然后,不同模块之间的通信主要通过 postMessage 进行消息推送,通过监听 onmessage 进行消息接收,实现主线程与 worker 线程之间通信。

// Demo 例子
/******* main.js *******/
const first = document.querySelector('#number1');
const second = document.querySelector('#number2');

const result = document.querySelector('.result');

if (window.Worker) {
  const myWorker = new Worker("worker.js");

  first.onchange = function() {
    myWorker.postMessage([first.value, second.value]);
    console.log('Message posted to worker');
  }

  second.onchange = function() {
    myWorker.postMessage([first.value, second.value]);
    console.log('Message posted to worker');
  }

  myWorker.onmessage = function(e) {
    result.textContent = e.data;
    console.log('Message received from worker');
  }
} else {
  console.log('Your browser doesn\'t support web workers.');
}


/******* worker.js *******/
onmessage = function(e) {
  console.log('Worker: Message received from main script');
  const result = e.data[0] * e.data[1];
  if (isNaN(result)) {
    postMessage('Please write two numbers');
  } else {
    const workerResult = 'Result: ' + result;
    console.log('Worker: Posting message back to main script');
    postMessage(workerResult);
  }
}

在 vue 项目中,如果直接使用,首先遇到的问题是worker文件路径与打包解析的问题。

解决方案一:暴力放到 public 文件目录,使用绝对路径引入(不够优雅,通用函数代码不能够通过 import 引入,难以使用 babel 转换高级语法等)

解决方案二:使用 worker-loader ,足够优雅。

使用 worker-loader 步骤如下:

// 安装依赖包
npm install worker-loader -D

vue.config.js 完整配置:

​
module.exports = {
  chainWebpack(config) {
    // set worker-loader
    config.module
      .rule('worker')
      .test(/\.worker\.js$/)
      .use('worker-loader')
      .loader('worker-loader')
      .end();
      
      // 解决:worker 热更新问题
      config.module
        .rule('js')
        .exclude
        .add(/\.worker\.js$/)
        .end();

      // 解决:“window is undefined”报错,这个是因为worker线程中不存在window对象,因此不能直接使用,要用this代替
      config.output.globalObject('this')
  },
  parallel: false
}

​

最后,使用的时候,我们不能调用原生的worker构造函数了,需要手动 import worker 文件,然后直接实例化这个文件即可。

// demo.worker.js
import Worker from './demo.worker.js'

let worker = new Worker()

标签:web,vue,const,Worker,worker,loader,result,js
From: https://blog.csdn.net/weixin_45963880/article/details/144418991

相关文章

  • springboot+mybatis plus+vue+elementui+axios 表格分页
    1、创建springboot项目2、pom.xml里面添加依赖<dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency>......
  • 《Web 安全攻防工具集:守护网络世界的利器》
    《Web安全攻防工具集:守护网络世界的利器》一、引言二、信息收集工具1.Nmap2.Goby3.Shodan4.Fofa5.WhatWeb6.Wappalyzer三、漏洞扫描工具1.AWVS2.IBMAppScan3.Nessus4.OpenVAS5.Xray四、漏洞利用工具1.Metasploit2.SQLmap3.BeEF4.BurpSuite5.OWASPZ......
  • 你有做过web端的压力测试吗?做压力测试有什么好处?怎么做?
    我作为一个大型语言模型,并没有一个实体的“身体”去直接进行web端的压力测试。我不能像一个用户那样打开浏览器,点击链接,填写表单。我的工作方式是处理和生成文本。但是,我可以提供关于web端压力测试的信息,以及如何进行压力测试的建议,包括你可以使用的工具和策略。Web端压力测试的......
  • 消防管理系统|Java|SSM|VUE| 前后端分离
                  【技术栈】1⃣️:架构:B/S、MVC2⃣️:系统环境:Windowsh/Mac3⃣️:开发环境:IDEA、JDK1.8、Maven、Mysql5.7+4⃣️:技术栈:Java、Mysql、SSM、Mybatis-Plus、VUE、jquery,html5⃣️数据库可视化工具:navicat6⃣️服务器:SpringBoot自带apachetom......
  • 校园二手物品交易市场系统|Java|SSM|VUE| 前后端分离
                 【技术栈】1⃣️:架构:B/S、MVC2⃣️:系统环境:Windowsh/Mac3⃣️:开发环境:IDEA、JDK1.8、Maven、Mysql5.7+4⃣️:技术栈:Java、Mysql、SSM、Mybatis-Plus、VUE、jquery,html5⃣️数据库可视化工具:navicat6⃣️服务器:SpringBoot自带apachetomca......
  • 【.NET】Windows 上快速部署.NET Core Web 项目
    一、为什么在Windows上部署二、Kestrel服务器的高性能三、将.NETCore项目作为Windows服务四、使用WinSW将.NETCore项目作为Windows服务五、案例一、为什么在Windows上部署在企业环境中,可能已经存在大量基于Windows的服务器和服务。如果你的.NETCore......
  • 基于JavaWeb的旅游网站系统
    引言  随着信息技术的迅猛发展,超市作为现代商业的重要组成部分,其管理系统的信息化程度直接影响着运营效率和服务质量。传统的超市管理模式在面对日益增长的客户需求时显得力不从心,尤其是在商品库存管理、销售数据分析和客户服务等方面存在诸多不足。基于此,本项目旨在开发......
  • 基于VUE的图书馆管理系统的设计与实现+vue源码+论文
    项目简介基于SSM实现的基于VUE的图书馆管理系统的设计与实现+vue源码+论文是一个旨在提高信息管理效率和规范性的现代化工具。该系统通过集中管理信息,实现了保密性强、效率高、存储空间大和成本低等多重优势。系统在Eclipse环境中使用Java语言编码,并采用Mysql创建数据表来保存......
  • 前端学习笔记-Vue篇-03
    3、使用Vue脚手架Home|VueCLI3.1具体步骤第一步(仅第一次执行):全局安装@vue/cli        npminstall-g@vue/clie第二步:切换到你要创建项目的目录,然后使用命令创建项目vuecreatexxxx第三步:启动项目npmrunserve3.2脚手架项目的结构-------......
  • springboot/ssm图书管理系统Java代码编写web项目图书商城借阅源码
    springboot/ssm图书管理系统Java代码编写web项目图书商城借阅源码基于springboot(可改ssm)+vue项目开发语言:Java框架:springboot/可改ssm+vueJDK版本:JDK1.8(或11)服务器:tomcat数据库:mysql5.7(或8.0)数据库工具:Navicat/sqlyog开发软件:eclipse/idea依赖管理包:Maven......