2019-06-13 23:44:43 +00:00
|
|
|
# [batchasync.js](https://git.coolaj86.com/coolaj86/batchasync.js)
|
2019-06-13 23:04:48 +00:00
|
|
|
|
2019-06-13 23:47:27 +00:00
|
|
|
Like calling `map()` and resolving with `Promise.all()`,
|
|
|
|
but handling a bounded number of items at any given time.
|
2019-06-13 23:44:43 +00:00
|
|
|
|
|
|
|
## Install
|
|
|
|
|
|
|
|
```bash
|
|
|
|
npm install --save batchasync
|
|
|
|
```
|
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
|
|
|
```js
|
|
|
|
// Browsers
|
|
|
|
var batchAsync = window.batchAsync;
|
|
|
|
```
|
|
|
|
|
|
|
|
```js
|
|
|
|
// Node
|
|
|
|
var batchAsync = require('batchasync').batchAsync;
|
|
|
|
```
|
|
|
|
|
|
|
|
```js
|
|
|
|
var batchSize = 4;
|
|
|
|
var things = ['apples', 'bananas', 'pears'];
|
|
|
|
|
|
|
|
function doStuff() {
|
|
|
|
// ... go fetch things
|
|
|
|
}
|
|
|
|
|
|
|
|
batchAsync(batchSize, things, doStuff).then(function(results) {
|
|
|
|
// all results, in order, just like Promise.all()
|
|
|
|
console.log(results[0]);
|
|
|
|
});
|
|
|
|
```
|
|
|
|
|
|
|
|
### Returning 'undefined'
|
|
|
|
|
|
|
|
Returning `undefined` will cause an exception to be thrown
|
|
|
|
(because it looks like a skipped promise). Return `null` instead.
|
|
|
|
|
|
|
|
**Example (bad)**:
|
|
|
|
|
|
|
|
```js
|
|
|
|
function doStuff(thing) {
|
|
|
|
// Oops! forgot to return
|
|
|
|
request('https://searchallthe.pictures/api/' + thing);
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
**Example (good)**:
|
|
|
|
|
|
|
|
```js
|
|
|
|
function doStuff(thing) {
|
|
|
|
return request('https://searchallthe.pictures/api/' + thing);
|
|
|
|
}
|
|
|
|
```
|
|
|
|
|
|
|
|
**Example (good)**:
|
|
|
|
|
|
|
|
```js
|
|
|
|
function doStuff(thing) {
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
```
|