
Neo-Async is thought to be used as a drop-in replacement for Async, it almost fully covers its functionality and runs faster.
Benchmark is here!
Bluebird's benchmark is here!
<script src="async.min.js"></script>
require(['async'], function(async) {});
I recommend to use Aigle.
It is optimized for Promise handling and has almost the same functionality as neo-async.
$ npm install neo-async
var async = require('neo-async');
$ npm install neo-async
$ ln -s ./node_modules/neo-async ./node_modules/async
var async = require('async');
bower install neo-async
* not in Async
eacheachSerieseachLimitforEach -> eachforEachSeries -> eachSeriesforEachLimit -> eachLimiteachOf -> eacheachOfSeries -> eachSerieseachOfLimit -> eachLimitforEachOf -> eachforEachOfSeries -> eachSerieseachOfLimit -> forEachLimitmapmapSeriesmapLimitmapValuesmapValuesSeriesmapValuesLimitfilterfilterSeriesfilterLimitselect -> filterselectSeries -> filterSeriesselectLimit -> filterLimitrejectrejectSeriesrejectLimitdetectdetectSeriesdetectLimitfind -> detectfindSeries -> detectSeriesfindLimit -> detectLimitpick *pickSeries *pickLimit *omit *omitSeries *omitLimit *reduceinject -> reducefoldl -> reducereduceRightfoldr -> reduceRighttransformtransformSeries *transformLimit *sortBysortBySeries *sortByLimit *somesomeSeriessomeLimitany -> someanySeries -> someSeriesanyLimit -> someLimiteveryeverySerieseveryLimitall -> everyallSeries -> everyallLimit -> everyconcatconcatSeriesconcatLimit *parallelseriesparallelLimittryEachwaterfallangelFall *angelfall -> angelFall *whilstdoWhilstuntildoUntilduringdoDuringforevercomposeseqapplyEachapplyEachSeriesqueuepriorityQueuecargoautoautoInjectretryretryableiteratortimestimesSeriestimesLimitraceapplysetImmediatenextTickmemoizeunmemoizeensureAsyncconstantasyncifywrapSync -> asyncifylogdirtimeoutreflectreflectAllcreateLogger$ git clone git@github.com:suguru03/async-benchmark.git
$ cd async-benchmark
$ npm install
$ node . // It might take more than one hour...
Neo-Async is 1.27 ~ 10.7 times faster than Async.
The value is the ratio (Neo-Async/Async) of the average speed.
| function | benchmark | func-comparator |
|---|---|---|
| each | 3.71 | 2.54 |
| eachSeries | 2.14 | 1.90 |
| eachLimit | 2.14 | 1.88 |
| eachOf | 3.30 | 2.50 |
| eachOfSeries | 1.97 | 1.83 |
| eachOfLimit | 2.02 | 1.80 |
| map | 4.20 | 4.11 |
| mapSeries | 2.40 | 3.65 |
| mapLimit | 2.64 | 2.66 |
| mapValues | 5.71 | 5.32 |
| mapValuesSeries | 3.82 | 3.23 |
| mapValuesLimit | 3.10 | 2.38 |
| filter | 8.11 | 8.76 |
| filterSeries | 5.79 | 4.86 |
| filterLimit | 4.00 | 3.32 |
| reject | 9.47 | 9.52 |
| rejectSeries | 7.39 | 4.64 |
| rejectLimit | 4.54 | 3.49 |
| detect | 6.67 | 6.37 |
| detectSeries | 3.54 | 3.73 |
| detectLimit | 2.38 | 2.62 |
| reduce | 4.13 | 3.23 |
| reduceRight | 4.23 | 3.24 |
| transform | 5.30 | 5.17 |
| sortBy | 2.24 | 2.37 |
| some | 6.39 | 6.10 |
| someSeries | 5.37 | 4.66 |
| someLimit | 3.39 | 2.84 |
| every | 6.85 | 6.27 |
| everySeries | 4.53 | 3.90 |
| everyLimit | 3.36 | 2.75 |
| concat | 9.18 | 9.35 |
| concatSeries | 7.49 | 6.09 |
| funciton | benchmark | func-comparator |
|---|---|---|
| parallel | 7.54 | 5.45 |
| series | 3.29 | 2.41 |
| waterfall | 5.12 | 4.27 |
| whilst | 1.96 | 1.95 |
| doWhilst | 2.07 | 1.96 |
| until | 2.10 | 1.99 |
| doUntil | 1.98 | 2.04 |
| during | 10.7 | 7.09 |
| doDuring | 5.98 | 6.03 |
| queue | 1.83 | 1.75 |
| priorityQueue | 1.79 | 1.75 |
| times | 3.84 | 3.65 |
| race | 1.45 | 1.27 |
| auto | 3.23 | 3.50 |
| retry | 9.43 | 6.78 |