# Async.js
[![Build Status via Travis CI](https://travis-ci.org/caolan/async.svg?branch=master)](https://travis-ci.org/caolan/async)
Async is a utility module which provides straight-forward, powerful functions
for working with asynchronous JavaScript. Although originally designed for
use with [Node.js](http://nodejs.org) and installable via `npm install async`,
it can also be used directly in the browser.
Async is also installable via:
- [bower](http://bower.io/): `bower install async`
- [component](https://github.com/component/component): `component install
caolan/async`
- [jam](http://jamjs.org/): `jam install async`
- [spm](http://spmjs.io/): `spm install async`
Async provides around 20 functions that include the usual 'functional'
suspects (`map`, `reduce`, `filter`, `each`…) as well as some common patterns
for asynchronous control flow (`parallel`, `series`, `waterfall`…). All these
functions assume you follow the Node.js convention of providing a single
callback as the last argument of your `async` function.
## Quick Examples
```javascript
async.map(['file1','file2','file3'], fs.stat, function(err, results){
// results is now an array of stats for each file
});
async.filter(['file1','file2','file3'], fs.exists, function(results){
// results now equals an array of the existing files
});
async.parallel([
function(){ ... },
function(){ ... }
], callback);
async.series([
function(){ ... },
function(){ ... }
]);
```
There are many more functions available so take a look at the docs below for a
full list. This module aims to be comprehensive, so if you feel anything is
missing please create a GitHub issue for it.
## Common Pitfalls
### Binding a context to an iterator
This section is really about `bind`, not about `async`. If you are wondering how to
make `async` execute your iterators in a given context, or are confused as to why
a method of another library isn't working as an iterator, study this example:
```js
// Here is a simple object with an (unnecessarily roundabout) squaring method
var AsyncSquaringLibrary = {
squareExponent: 2,
square: function(number, callback){
var result = Math.pow(number, this.squareExponent);
setTimeout(function(){
callback(null, result);
}, 200);
}
};
async.map([1, 2, 3], AsyncSquaringLibrary.square, function(err, result){
// result is [NaN, NaN, NaN]
// This fails because the `this.squareExponent` expression in the square
// function is not evaluated in the context of AsyncSquaringLibrary, and is
// therefore undefined.
});
async.map([1, 2, 3], AsyncSquaringLibrary.square.bind(AsyncSquaringLibrary), function(err, result){
// result is [1, 4, 9]
// With the help of bind we can attach a context to the iterator before
// passing it to async. Now the square function will be executed in its
// 'home' AsyncSquaringLibrary context and the value of `this.squareExponent`
// will be as expected.
});
```
## Download
The source is available for download from
[GitHub](http://github.com/caolan/async).
Alternatively, you can install using Node Package Manager (`npm`):
npm install async
__Development:__ [async.js](https://github.com/caolan/async/raw/master/lib/async.js) - 29.6kb Uncompressed
## In the Browser
So far it's been tested in IE6, IE7, IE8, FF3.6 and Chrome 5.
Usage:
```html
<script type="text/javascript" src="async.js"></script>
<script type="text/javascript">
async.map(data, asyncProcess, function(err, results){
alert(results);
});
</script>
```
## Documentation
### Collections
* [`each`](#each)
* [`eachSeries`](#eachSeries)
* [`eachLimit`](#eachLimit)
* [`map`](#map)
* [`mapSeries`](#mapSeries)
* [`mapLimit`](#mapLimit)
* [`filter`](#filter)
* [`filterSeries`](#filterSeries)
* [`reject`](#reject)
* [`rejectSeries`](#rejectSeries)
* [`reduce`](#reduce)
* [`reduceRight`](#reduceRight)
* [`detect`](#detect)
* [`detectSeries`](#detectSeries)
* [`sortBy`](#sortBy)
* [`some`](#some)
* [`every`](#every)
* [`concat`](#concat)
* [`concatSeries`](#concatSeries)
### Control Flow
* [`series`](#seriestasks-callback)
* [`parallel`](#parallel)
* [`parallelLimit`](#parallellimittasks-limit-callback)
* [`whilst`](#whilst)
* [`doWhilst`](#doWhilst)
* [`until`](#until)
* [`doUntil`](#doUntil)
* [`forever`](#forever)
* [`waterfall`](#waterfall)
* [`compose`](#compose)
* [`seq`](#seq)
* [`applyEach`](#applyEach)
* [`applyEachSeries`](#applyEachSeries)
* [`queue`](#queue)
* [`priorityQueue`](#priorityQueue)
* [`cargo`](#cargo)
* [`auto`](#auto)
* [`retry`](#retry)
* [`iterator`](#iterator)
* [`apply`](#apply)
* [`nextTick`](#nextTick)
* [`times`](#times)
* [`timesSeries`](#timesSeries)
### Utils
* [`memoize`](#memoize)
* [`unmemoize`](#unmemoize)
* [`log`](#log)
* [`dir`](#dir)
* [`noConflict`](#noConflict)
## Collections
<a name="forEach" />
<a name="each" />
### each(arr, iterator, callback)
Applies the function `iterator` to each item in `arr`, in parallel.
The `iterator` is called with an item from the list, and a callback for when it
has finished. If the `iterator` passes an error to its `callback`, the main
`callback` (for the `each` function) is immediately called with the error.
Note, that since this function applies `iterator` to each item in parallel,
there is no guarantee that the iterator functions will complete in order.
__Arguments__
* `arr` - An array to iterate over.
* `iterator(item, callback)` - A function to apply to each item in `arr`.
The iterator is passed a `callback(err)` which must be called once it has
completed. If no error has occurred, the `callback` should be run without
arguments or with an explicit `null` argument.
* `callback(err)` - A callback which is called when all `iterator` functions
have finished, or an error occurs.
__Examples__
```js
// assuming openFiles is an array of file names and saveFile is a function
// to save the modified contents of that file:
async.each(openFiles, saveFile, function(err){
// if any of the saves produced an error, err would equal that error
});
```
```js
// assuming openFiles is an array of file names
async.each(openFiles, function(file, callback) {
// Perform operation on file here.
console.log('Processing file ' + file);
if( file.length > 32 ) {
console.log('This file name is too long');
callback('File name too long');
} else {
// Do work to process file here
console.log('File processed');
callback();
}
}, function(err){
// if any of the file processing produced an error, err would equal that error
if( err ) {
// One of the iterations produced an error.
// All processing will now stop.
console.log('A file failed to process');
} else {
console.log('All files have been processed successfully');
}
});
```
---------------------------------------
<a name="forEachSeries" />
<a name="eachSeries" />
### eachSeries(arr, iterator, callback)
The same as [`each`](#each), only `iterator` is applied to each item in `arr` in
series. The next `iterator` is only called once the current one has completed.
This means the `iterator` functions will complete in order.
---------------------------------------
<a name="forEachLimit" />
<a name="eachLimit" />
### eachLimit(arr, limit, iterator, callback)
The same as [`each`](#each), only no more than `limit` `iterator`s will be simultaneously
running at any time.
Note that the items in `arr` are not processed in batches, so there is no guarantee that
the first `limit` `iterator` functions will complete before any others are started.
__Arguments__
* `arr` - An array to iterate over.
* `limit` - The maximum number of `iterator`s to run at any time.
* `iterator(item, callback)` - A function to apply to each item in `arr`.
The iterator is passed a `callback(err)` which must be called once it has
completed. If no error has occurred, the callback should be run without
arguments or with an explicit `nu
没有合适的资源?快使用搜索试试~ 我知道了~
温馨提示
解决npm 在线安装phantomjs失败问题,phantomjs现已经改名phantomjs-prebuilt; 将压缩包解压到 %NODE_HOME%/lib/node_modules/ 进入 %NODE_HOME%/bin 然后执行如下命令,建立软连接: ln -s ../lib/node_modules/phantomjs/bin/phantomjs
资源推荐
资源详情
资源评论
收起资源包目录
phantomjs@1.9.7-1 nodejs离线包 (553个子文件)
ctio.3ctype 8KB
a 16B
a 12B
AUTHORS 235B
b 10B
b 0B
LICENSE.BSD 1KB
builtin 22B
phantomjs-1.9.7-linux-x86_64.tar.bz2 12.55MB
benchmark-native.c 613B
c 0B
ChangeLog 15KB
CHANGELOG 2KB
page_events.coffee 4KB
printheaderfooter.coffee 3KB
walk_through_frames.coffee 3KB
netsniff.coffee 3KB
run-qunit.coffee 2KB
run-jasmine.coffee 2KB
waitfor.coffee 2KB
render_multi_url.coffee 2KB
server.coffee 1KB
direction.coffee 1KB
colorwheel.coffee 1KB
detectsniff.coffee 1KB
simpleserver.coffee 1KB
tweets.coffee 1022B
weather.coffee 1020B
rasterize.coffee 928B
serverkeepalive.coffee 909B
printmargins.coffee 839B
postserver.coffee 772B
injectme.coffee 739B
seasonfood.coffee 731B
follow.coffee 712B
features.coffee 655B
imagebin.coffee 590B
loadurlwithoutcss.coffee 586B
technews.coffee 581B
stdin-stdout-stderr.coffee 564B
child_process-examples.coffee 549B
pagecallback.coffee 543B
pizza.coffee 518B
netlog.coffee 518B
echoToFile.coffee 503B
sleepsort.coffee 499B
loadspeed.coffee 492B
movies.coffee 469B
unrandomize.coffee 468B
scandir.coffee 462B
phantomwebintro.coffee 442B
ipgeocode.coffee 392B
useragent.coffee 371B
post.coffee 320B
outputEncoding.coffee 312B
fibo.coffee 224B
arguments.coffee 197B
version.coffee 174B
printenv.coffee 152B
countdown.coffee 126B
module.coffee 110B
hello.coffee 43B
jsl.conf 6KB
d 0B
e 0B
.editorconfig 188B
.dir-locals.el 178B
.env 0B
f 0B
.gitmodules 207B
globalconfig 25B
bench.gnu 6KB
test.html 340B
foo.ini 947B
psl.js 158KB
psl.min.js 134KB
cookie.js 50KB
ctio.js 43KB
modernizr.js 42KB
request.js 41KB
async.js 34KB
deflater.js 32KB
index.js 30KB
browser.js 30KB
server.js 27KB
ctype.js 25KB
browser.js 21KB
url-parse.js 21KB
server.js 17KB
index.js 16KB
uri.js 16KB
inflater.js 14KB
adm-zip.js 14KB
index.js 14KB
config-defs.js 13KB
test.js 13KB
punycode.es6.js 12KB
punycode.js 12KB
index.js 12KB
nopt.js 11KB
共 553 条
- 1
- 2
- 3
- 4
- 5
- 6
资源评论
恋奴娇
- 粉丝: 28
- 资源: 24
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功