在react-create-app中使用webWorker的一种解决办法

安装依赖

yarn add react-app-rewired 或者 npm install react-app-rewired
yarn add customize-cra worker-loader babel-loader --dev 或者 npm install customize-cra worker-loader babel-loader --dev

替换package.json中的scripts

"scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "test": "react-app-rewired test",
    "eject": "react-app-rewired eject"
  }

在项目根目录下新建config-overrides.js

内容如下

const {
   override,
   addWebpackModuleRule
 } = require("customize-cra");
 
module.exports = {
   webpack: override(
     addWebpackModuleRule({
       test: /\.worker\.(c|m)?js$/i, 
       use: [{
           loader: 'worker-loader',
       },{
         loader: 'babel-loader',
         options: {
           presets: ['@babel/preset-env'],
         },
       }
     ]
     }),
   )
};

应用示例

my.worker.js

onmessage = function (event) {
  const workerResult = event.data;

  workerResult.onmessage = true;

  postMessage(workerResult);
};

index.js

import Worker from './my.worker.js';

const worker = new Worker();

let result;

worker.onmessage = (event) => {
  if (!result) {
    result = document.createElement('div');
    result.setAttribute('id', 'result');

    document.body.append(result);
  }

  result.innerText = JSON.stringify(event.data);
};

const button = document.getElementById('button');

button.addEventListener('click', () => {
  worker.postMessage({ postMessage: true });
});
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值