# 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
没有合适的资源?快使用搜索试试~ 我知道了~
COMP2406-AS3:作业 3 - COMP 2406A
共1032个文件
js:524个
md:112个
json:110个
需积分: 10 1 下载量 167 浏览量
2021-07-14
15:38:04
上传
评论
收藏 1.73MB ZIP 举报
温馨提示
本杰明·斯威特 (100846396) 布雷登·吉拉德 (100852106) 过去,教授经常收到学生发来的电子邮件,他们想知道为什么他们朋友的作业已经被标记了,为什么他们的作业还没有被标记。 这通常是因为一名助教比其他助教提前完成了评分,并且在评分截止日期之前完成了评分。 为了帮助减少这些担忧并帮助管理助教的任务,计算机科学学院在最近的课程中保留了一个评分进度表。 学生们发现教授和助教发布这些信息很有帮助,并且有助于管理助教任务。 不幸的是,更新图表完全是手动的。 当一项作业完成时,教授。 将编辑图表并输入标记开始日期和预期完成日期以及指示标记“正在进行”的注释,然后将文件保存回网站。 当助教完成评分并在 culearn 中输入评分后,他们会通过电子邮件发送给教授。 谁然后再次编辑图表并输入完成日期并将评论修改为“准时”或“迟到”。 我们建立了一个服务器来管理图表并允许学生教授。
资源详情
资源评论
资源推荐
收起资源包目录
COMP2406-AS3:作业 3 - COMP 2406A (1032个子文件)
LICENSE.APACHE2 586B
LICENSE.APACHE2 586B
LICENSE.APACHE2 586B
LICENSE.APACHE2 586B
uglifyjs.cmd 145B
uglifyjs.cmd 145B
uglifyjs.cmd 141B
jade.cmd 133B
CONTRIBUTORS 524B
bootstrap.css 121KB
bootstrap.min.css 101KB
bootstrap-responsive.css 21KB
bootstrap-responsive.min.css 16KB
style.css 429B
.DS_Store 12KB
.DS_Store 6KB
.DS_Store 6KB
root_dir2_file1.ext1 0B
root_file1.ext1 0B
root_dir1_file1.ext1 0B
root1_dir1_subdir1_file1.ext1 0B
root_dir2_file2.ext2 0B
root_dir1_file2.ext2 0B
root_file2.ext2 0B
root_file3.ext3 0B
root_dir1_file3.ext3 0B
.gitattributes 483B
.gitignore 316B
.gitmodules 207B
.gitmodules 207B
favicon.ico 2KB
favicon.ico 1KB
prof.jade 6KB
ta.jade 6KB
student.jade 5KB
index.jade 449B
tablelayout.jade 285B
jade 272B
layout.jade 243B
error.jade 121B
jade.js 480KB
compress.js 101KB
compress.js 101KB
jquery.min.js 91KB
compress.js 80KB
bootstrap.js 57KB
parse.js 51KB
parse.js 51KB
parse.js 49KB
output.js 43KB
output.js 43KB
output.js 39KB
ast.js 32KB
ast.js 32KB
ast.js 31KB
bootstrap.min.js 31KB
async.js 29KB
async.js 29KB
minimatch.js 28KB
scope.js 21KB
scope.js 20KB
scope.js 20KB
test-source-node.js 20KB
lexer.js 20KB
test-source-map-generator.js 19KB
compiler.js 18KB
index.js 18KB
parser.js 18KB
source-map-consumer.js 18KB
response.js 18KB
source-map-consumer.js 17KB
source-map-consumer.js 17KB
transformers.js 17KB
vars.js 17KB
test-source-map-consumer.js 17KB
test-source-node.js 16KB
test-source-node.js 16KB
test-source-map-generator.js 15KB
test-source-map-generator.js 15KB
test-source-map-consumer.js 15KB
test-source-map-consumer.js 15KB
basic.js 15KB
source-map-generator.js 14KB
source-node.js 14KB
source-map-generator.js 14KB
source-map-generator.js 14KB
source-node.js 14KB
source-node.js 14KB
index.js 14KB
index.js 14KB
index.js 14KB
test.js 13KB
index.js 13KB
application.js 12KB
mozilla-ast.js 11KB
mozilla-ast.js 11KB
mozilla-ast.js 11KB
parse.js 10KB
parse.js 10KB
parse.js 10KB
共 1032 条
- 1
- 2
- 3
- 4
- 5
- 6
- 11
Fl4me
- 粉丝: 34
- 资源: 4600
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
最新资源
- javaweb毕业设计-java作业管理系统设计(源代码+lw)(可做课程设计).rar
- 我的自己111111111
- 判断一个数是否为质数以及通过C语言实现.docx
- IPv4-HEADER-03 测试数据
- 高级网络人才培训专家-X00070005 第32章 ISDN和DCC
- 高级网络人才培训专家-X00070004 第31章 配置帧中继
- IPv4-HEADER-02测试数据
- tensorflow-2.6.2-cp38-cp38-manylinux2010-x86-64.whl
- tensorflow-2.6.2-cp37-cp37m-win-amd64.whl
- RV180-Firmware-1.0.5.4.img
资源上传下载、课程学习等过程中有任何疑问或建议,欢迎提出宝贵意见哦~我们会及时处理!
点击此处反馈
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功
评论0