# Async.js
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), it can also be used directly in the
browser. Also supports [component](https://github.com/component/component).
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](#series)
* [parallel](#parallel)
* [parallelLimit](#parallellimittasks-limit-callback)
* [whilst](#whilst)
* [doWhilst](#doWhilst)
* [until](#until)
* [doUntil](#doUntil)
* [forever](#forever)
* [waterfall](#waterfall)
* [compose](#compose)
* [applyEach](#applyEach)
* [applyEachSeries](#applyEachSeries)
* [queue](#queue)
* [cargo](#cargo)
* [auto](#auto)
* [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 an iterator function to each item in an array, 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 this callback, the main
callback for the each function is immediately called with the error.
Note, that since this function applies the 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 the array.
The iterator is passed a callback(err) which must be called once it has
completed. If no error has occured, the callback should be run without
arguments or with an explicit null argument.
* callback(err) - A callback which is called after all the iterator functions
have finished, or an error has occurred.
__Example__
```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
});
```
---------------------------------------
<a name="forEachSeries" />
<a name="eachSeries" />
### eachSeries(arr, iterator, callback)
The same as each only the iterator is applied to each item in the array in
series. The next iterator is only called once the current one has completed
processing. This means the iterator functions will complete in order.
---------------------------------------
<a name="forEachLimit" />
<a name="eachLimit" />
### eachLimit(arr, limit, iterator, callback)
The same as each only no more than "limit" iterators will be simultaneously
running at any time.
Note that the items 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 iterators to run at any time.
* iterator(item, callback) - A function to apply to each item in the array.
The iterator is passed a callback(err) which must be called once it has
completed. If no error has occured, the callback should be run without
arguments or with an explicit null argument.
* callback(err) - A callback which is called after all the iterator functions
have finished, or an error has occurred.
__Example__
```js
// Assume documents is an array of JSON objects and requestApi is a
// function that interacts with a rate-limited REST api.
async.eachLimit(documents, 20, requestApi, function(err){
// if any of the saves produced an error, err would equal that error
});
```
---------------------------------------
<a name="map" />
### map(arr, iterator, callback)
Produces a new array of values by mapping each value in the given array through
the iterator function. The iterator is called with an item from the array and a
callback for when it has finished processing. The callback takes 2 arguments,
an error and the transformed item from the array. If the iterator passes an
error to this callback, the main callback for the map function is immediately
called with the error.
Note, that since this function applies the iterator to each item in parallel
there is no guarantee that the iterator functions will complete in order, however
the results array will be in the same order as the original array.
__Arguments__
* arr - An array to iterate over.
* iterator(item, callback) - A function to apply to each item in the array.
The iterator is passed a callback(err, transformed) which must be called onc
没有合适的资源?快使用搜索试试~ 我知道了~
lv2插件安装包.zip
共2816个文件
js:2011个
md:141个
json:92个
1.该资源内容由用户上传,如若侵权请联系客服进行举报
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
2.虚拟产品一经售出概不退款(资源遇到问题,请及时私信上传者)
版权申诉
0 下载量 24 浏览量
2022-04-03
23:10:40
上传
评论
收藏 9.39MB ZIP 举报
温馨提示
lv2插件安装包.zip
资源推荐
资源详情
资源评论
收起资源包目录
lv2插件安装包.zip (2816个子文件)
AUTHORS 235B
.babelrc 65B
.babelrc 32B
.babelrc 32B
.babelrc 32B
.babelrc 32B
.babelrc 32B
.bowerrc 37B
.bowerrc 37B
Agent.cc 29KB
ScreenBufferTest.cc 21KB
winpty.cc 18KB
ConsoleFont.cc 17KB
ConsoleInput.cc 16KB
pty.cc 16KB
main.cc 16KB
CreateProcess_InheritList.cc 15KB
Terminal.cc 14KB
WorkerProgram.cc 13KB
TestUtil.cc 11KB
Traditional.cc 10KB
pty.cc 9KB
Modern.cc 8KB
CreateProcess_Duplicate.cc 8KB
MiscTests.cc 8KB
CreateProcess_UseStdHandles.cc 7KB
Win32Console.cc 7KB
NamedPipe.cc 7KB
RemoteHandle.cc 7KB
UnicodeWideTest1.cc 6KB
ConsoleLine.cc 5KB
SetFont.cc 5KB
Spawn.cc 5KB
RemoteWorker.cc 5KB
TestUtil.cc 5KB
ScreenBufferTest2.cc 5KB
Test_GetConsoleTitleW.cc 4KB
VeryLargeRead.cc 4KB
Win7_Conout_Crash.cc 4KB
trivial_test.cc 4KB
UnicodeWideTest2.cc 4KB
Util.cc 4KB
CreateProcess.cc 4KB
DebugClient.cc 3KB
UnicodeEncodingTest.cc 3KB
EventLoop.cc 3KB
CreateProcess_Duplicate_PseudoHandleBug.cc 3KB
UnicodeDoubleWidthTest.cc 3KB
LargeConsoleRead.cc 3KB
QueryFont.cc 3KB
Win7Bug_RaceCondition.cc 2KB
NtHandleQuery.cc 2KB
ClearConsole.cc 2KB
Win32Test3.cc 2KB
BufferResizeTests.cc 2KB
DebugServer.cc 2KB
CreateProcess_Detached.cc 2KB
main.cc 2KB
Win32Test2.cc 2KB
UnixEcho.cc 2KB
CreateProcess_Duplicate_XPPipeBug.cc 2KB
ChangeScreenBuffer.cc 2KB
CreateProcess_InheritAllHandles.cc 2KB
Win10ResizeWhileFrozen.cc 2KB
CreateProcess_NewConsole.cc 2KB
WinptyAssert.cc 2KB
winpty_wcsnlen.cc 1KB
SmallRect.cc 1KB
Win32Write1.cc 1KB
Coord.cc 1KB
VkEscapeTest.cc 1KB
ShowConsoleInput.cc 1KB
Utf16Echo.cc 1KB
Win10WrapTest1.cc 1KB
ShmemParcel.cc 1KB
SelectAllTest.cc 1KB
UnicodeConversions.cc 1KB
main.cc 1013B
Win32Test1.cc 986B
OSVersion.cc 906B
Win7Bug_InheritHandles.cc 867B
Event.cc 709B
Win10WrapTest2.cc 591B
Win32Echo1.cc 531B
Win32Echo2.cc 307B
WinptyVersion.cc 296B
ShowArgv.cc 287B
SetCursorPos.cc 219B
CHANGES 27KB
CHANGES 27KB
CHANGES 2KB
CHANGES 2KB
CHANGES 1KB
CHANGES 1KB
CHANGES 1KB
CHANGES 1KB
CHANGES 988B
CHANGES 988B
CHANGES 753B
CHANGES 753B
共 2816 条
- 1
- 2
- 3
- 4
- 5
- 6
- 29
资源评论
卷积神经网络
- 粉丝: 338
- 资源: 8460
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功