parallel.es
data:image/s3,"s3://crabby-images/da741/da74173eb7e659977497b488c2da4b59f7450ec0" alt="Coverage Status"
A JavaScript library that simplifies parallel computation in the browser (and other environments soon).
Getting Started
Install the library using npm:
npm install --save parallel-es
Perform a single computation on a worker thread:
import parallel from "parallel-es";
parallel.run(function () {
return [1, 2, 3];
}).then(result => console.log(result));
Or use the reactive api that automatically schedules the work onto multiple worker without any additional doing:
parallel.range(0, 100000)
.map(value => value * value)
.then(result => console.log(result));
Debugging Support
The Library uses Function serialization and therefore debugging is not supported out of the box. However, there is a webpack plugin that rewrites your code in a way that allows debugging (at least in Chrome and Firefox Nightly).
Referencing Functions and Variables
The library uses function serialization and therefore the outer scope is no longer available when the function is invoked in the worker thread. However, there is a webpack plugin that rewrites your code and allows you to use const variables from the outer scope or reference functions.
Documentation
The API Documentation is available online. The wiki describes the architecture and programing model in more detail.
Examples
More sophisticated examples can be seen here.
Browsers support made by @godban
data:image/s3,"s3://crabby-images/8f278/8f278d33d9200329b13e52b3063120007792f396" alt="IE / Edge" IE / Edge | data:image/s3,"s3://crabby-images/798f7/798f776bd162a53d122c9789486e6f91fe1159a1" alt="Firefox" Firefox | data:image/s3,"s3://crabby-images/59b47/59b47584e36103b9dece6667699b9d958f589a03" alt="Chrome" Chrome | data:image/s3,"s3://crabby-images/86421/8642110d18f5b1e77b6b888e9b3d1247df50b3b7" alt="Safari" Safari | data:image/s3,"s3://crabby-images/99398/99398240146b45e096b1f69f9ae28ebfc210325f" alt="Opera" Opera | data:image/s3,"s3://crabby-images/7163e/7163e5f31ce6d6f5ea3f49c586150c260b68ba5a" alt="iOS Safari" iOS Safari | data:image/s3,"s3://crabby-images/fc7b1/fc7b1937bb9ee76ee645c005f4c0188e4d4f9727" alt="Chrome for Android" Android |
---|
IE10, IE11, Edge | last 2 versions | last 2 versions | last 2 versions | last 2 versions | iOS 5.1, iOS 6, iOS 7, iOS 8, iOS 9 | Chrome, Android 4.4 |
Automated browser testing is performed using BrowserStack's open source offer.
data:image/s3,"s3://crabby-images/fd159/fd159aa8f9f63d82b0f2941a1e9841e69a17fd21" alt="BrowserStack"