You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
Björn b963b3396c
init
5 years ago
..
dist init 5 years ago
internal init 5 years ago
CHANGELOG.md init 5 years ago
LICENSE init 5 years ago
README.md init 5 years ago
all.js init 5 years ago
allLimit.js init 5 years ago
allSeries.js init 5 years ago
any.js init 5 years ago
anyLimit.js init 5 years ago
anySeries.js init 5 years ago
apply.js init 5 years ago
applyEach.js init 5 years ago
applyEachSeries.js init 5 years ago
asyncify.js init 5 years ago
auto.js init 5 years ago
autoInject.js init 5 years ago
bower.json init 5 years ago
cargo.js init 5 years ago
compose.js init 5 years ago
concat.js init 5 years ago
concatLimit.js init 5 years ago
concatSeries.js init 5 years ago
constant.js init 5 years ago
detect.js init 5 years ago
detectLimit.js init 5 years ago
detectSeries.js init 5 years ago
dir.js init 5 years ago
doDuring.js init 5 years ago
doUntil.js init 5 years ago
doWhilst.js init 5 years ago
during.js init 5 years ago
each.js init 5 years ago
eachLimit.js init 5 years ago
eachOf.js init 5 years ago
eachOfLimit.js init 5 years ago
eachOfSeries.js init 5 years ago
eachSeries.js init 5 years ago
ensureAsync.js init 5 years ago
every.js init 5 years ago
everyLimit.js init 5 years ago
everySeries.js init 5 years ago
filter.js init 5 years ago
filterLimit.js init 5 years ago
filterSeries.js init 5 years ago
find.js init 5 years ago
findLimit.js init 5 years ago
findSeries.js init 5 years ago
foldl.js init 5 years ago
foldr.js init 5 years ago
forEach.js init 5 years ago
forEachLimit.js init 5 years ago
forEachOf.js init 5 years ago
forEachOfLimit.js init 5 years ago
forEachOfSeries.js init 5 years ago
forEachSeries.js init 5 years ago
forever.js init 5 years ago
groupBy.js init 5 years ago
groupByLimit.js init 5 years ago
groupBySeries.js init 5 years ago
index.js init 5 years ago
inject.js init 5 years ago
log.js init 5 years ago
map.js init 5 years ago
mapLimit.js init 5 years ago
mapSeries.js init 5 years ago
mapValues.js init 5 years ago
mapValuesLimit.js init 5 years ago
mapValuesSeries.js init 5 years ago
memoize.js init 5 years ago
nextTick.js init 5 years ago
package.json init 5 years ago
parallel.js init 5 years ago
parallelLimit.js init 5 years ago
priorityQueue.js init 5 years ago
queue.js init 5 years ago
race.js init 5 years ago
reduce.js init 5 years ago
reduceRight.js init 5 years ago
reflect.js init 5 years ago
reflectAll.js init 5 years ago
reject.js init 5 years ago
rejectLimit.js init 5 years ago
rejectSeries.js init 5 years ago
retry.js init 5 years ago
retryable.js init 5 years ago
select.js init 5 years ago
selectLimit.js init 5 years ago
selectSeries.js init 5 years ago
seq.js init 5 years ago
series.js init 5 years ago
setImmediate.js init 5 years ago
some.js init 5 years ago
someLimit.js init 5 years ago
someSeries.js init 5 years ago
sortBy.js init 5 years ago
timeout.js init 5 years ago
times.js init 5 years ago
timesLimit.js init 5 years ago
timesSeries.js init 5 years ago
transform.js init 5 years ago
tryEach.js init 5 years ago
unmemoize.js init 5 years ago
until.js init 5 years ago
waterfall.js init 5 years ago
whilst.js init 5 years ago
wrapSync.js init 5 years ago

README.md

Async Logo

Build Status via Travis CI NPM version Coverage Status Join the chat at https://gitter.im/caolan/async libhive - Open source examples jsDelivr Hits

Async is a utility module which provides straight-forward, powerful functions for working with asynchronous JavaScript. Although originally designed for use with Node.js and installable via npm install --save async, it can also be used directly in the browser.

This version of the package is optimized for the Node.js environment. If you use Async with webpack, install async-es instead.

For Documentation, visit https://caolan.github.io/async/

For Async v1.5.x documentation, go HERE

// for use with Node-style callbacks...
var async = require("async");

var obj = {dev: "/dev.json", test: "/test.json", prod: "/prod.json"};
var configs = {};

async.forEachOf(obj, (value, key, callback) => {
    fs.readFile(__dirname + value, "utf8", (err, data) => {
        if (err) return callback(err);
        try {
            configs[key] = JSON.parse(data);
        } catch (e) {
            return callback(e);
        }
        callback();
    });
}, err => {
    if (err) console.error(err.message);
    // configs is now a map of JSON data
    doSomethingWith(configs);
});
var async = require("async");

// ...or ES2017 async functions
async.mapLimit(urls, 5, async function(url) {
    const response = await fetch(url)
    return response.body
}, (err, results) => {
    if (err) throw err
    // results is now an array of the response bodies
    console.log(results)
})