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 f184cd7e2a adding 4 years ago
..
dist adding 4 years ago
internal adding 4 years ago
CHANGELOG.md adding 4 years ago
LICENSE adding 4 years ago
README.md adding 4 years ago
all.js adding 4 years ago
allLimit.js adding 4 years ago
allSeries.js adding 4 years ago
any.js adding 4 years ago
anyLimit.js adding 4 years ago
anySeries.js adding 4 years ago
apply.js adding 4 years ago
applyEach.js adding 4 years ago
applyEachSeries.js adding 4 years ago
asyncify.js adding 4 years ago
auto.js adding 4 years ago
autoInject.js adding 4 years ago
bower.json adding 4 years ago
cargo.js adding 4 years ago
compose.js adding 4 years ago
concat.js adding 4 years ago
concatLimit.js adding 4 years ago
concatSeries.js adding 4 years ago
constant.js adding 4 years ago
detect.js adding 4 years ago
detectLimit.js adding 4 years ago
detectSeries.js adding 4 years ago
dir.js adding 4 years ago
doDuring.js adding 4 years ago
doUntil.js adding 4 years ago
doWhilst.js adding 4 years ago
during.js adding 4 years ago
each.js adding 4 years ago
eachLimit.js adding 4 years ago
eachOf.js adding 4 years ago
eachOfLimit.js adding 4 years ago
eachOfSeries.js adding 4 years ago
eachSeries.js adding 4 years ago
ensureAsync.js adding 4 years ago
every.js adding 4 years ago
everyLimit.js adding 4 years ago
everySeries.js adding 4 years ago
filter.js adding 4 years ago
filterLimit.js adding 4 years ago
filterSeries.js adding 4 years ago
find.js adding 4 years ago
findLimit.js adding 4 years ago
findSeries.js adding 4 years ago
foldl.js adding 4 years ago
foldr.js adding 4 years ago
forEach.js adding 4 years ago
forEachLimit.js adding 4 years ago
forEachOf.js adding 4 years ago
forEachOfLimit.js adding 4 years ago
forEachOfSeries.js adding 4 years ago
forEachSeries.js adding 4 years ago
forever.js adding 4 years ago
groupBy.js adding 4 years ago
groupByLimit.js adding 4 years ago
groupBySeries.js adding 4 years ago
index.js adding 4 years ago
inject.js adding 4 years ago
log.js adding 4 years ago
map.js adding 4 years ago
mapLimit.js adding 4 years ago
mapSeries.js adding 4 years ago
mapValues.js adding 4 years ago
mapValuesLimit.js adding 4 years ago
mapValuesSeries.js adding 4 years ago
memoize.js adding 4 years ago
nextTick.js adding 4 years ago
package.json adding 4 years ago
parallel.js adding 4 years ago
parallelLimit.js adding 4 years ago
priorityQueue.js adding 4 years ago
queue.js adding 4 years ago
race.js adding 4 years ago
reduce.js adding 4 years ago
reduceRight.js adding 4 years ago
reflect.js adding 4 years ago
reflectAll.js adding 4 years ago
reject.js adding 4 years ago
rejectLimit.js adding 4 years ago
rejectSeries.js adding 4 years ago
retry.js adding 4 years ago
retryable.js adding 4 years ago
select.js adding 4 years ago
selectLimit.js adding 4 years ago
selectSeries.js adding 4 years ago
seq.js adding 4 years ago
series.js adding 4 years ago
setImmediate.js adding 4 years ago
some.js adding 4 years ago
someLimit.js adding 4 years ago
someSeries.js adding 4 years ago
sortBy.js adding 4 years ago
timeout.js adding 4 years ago
times.js adding 4 years ago
timesLimit.js adding 4 years ago
timesSeries.js adding 4 years ago
transform.js adding 4 years ago
tryEach.js adding 4 years ago
unmemoize.js adding 4 years ago
until.js adding 4 years ago
waterfall.js adding 4 years ago
whilst.js adding 4 years ago
wrapSync.js adding 4 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)
})