内容简介:Use web workers with react hookBefore you start using thisMore examples:
Use web workers with react hook
https://useworker.js.org/
:art:
Features
- Run expensive function without blocking UI ( Show live gif )
- Supports Promises pattern instead of event-messages
- Size:
< 1KB, withzerodependencies - Clear API using hook
:floppy_disk:
Install
npm install --save @koale/useworker
:hammer:
Import
import { useWorker, WORKER_STATUS } from "@koale/useworker";
:orange_book:
Documents
:bread:
Demo
- Sorting : Sorting 50000 random numbers
- Csv : Generate Csv, Parse Csv, Convert to JSON
- External Dependencies Use external scripts inside WebWorkers
⚙ Web Workers
Before you start using this hook , I suggest you to read the Web Worker documentation.
:feet:
Usage
import React from "react";
import { useWorker } from "@koale/useworker";
const numbers = [...Array(5000000)].map(e => ~~(Math.random() * 1000000));
const sortNumbers = nums => nums.sort();
const Example = () => {
const [sortWorker] = useWorker(sortNumbers);
const runSort = async () => {
const result = await sortWorker(numbers); // non-blocking UI
console.log("End.");
};
return (
<button type="button" onClick={runSort}>
Run Sort
</button>
);
};
:feet:
Examples
More examples: https://github.com/alewin/useWorker/tree/develop/example
:wrench:
Roadmap
- import and use external script inside
useWorkerfunction - import and use local script inside
useWorkerfunction - run multiple instance of the worker
:earth_asia:
Contribute? Bug? New Feature?
The library is experimental so if you find a bug or would like to request a new feature , open an issue
:bulb:
Similar Project
:scroll:
License
MIT © alewin
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
CSS 压缩/解压工具
在线压缩/解压 CSS 代码
在线进制转换器
各进制数互转换器