Javascript 비동기 프로 그래 밍 async 실현 과정 상세 설명
5827 단어 Javascript비동기프로 그래 밍async
소개 하 다.
node 설치
npm install async --save
쓰다var async = require('async')
js 파일https://github.com/caolan/async/tree/master/dist
async 는 비동기 프로 세 스 제어 에 사용 되 는 많은 함 수 를 제공 합 니 다.다음은 async 핵심 함수 입 니 다.완전한 함 수 는 보 세 요async 공식 DOC
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'], function(filePath, callback) {
fs.access(filePath, function(err) {
callback(null, !err)
});
}, function(err, results) {
// results now equals an array of the existing files
});
async.parallel([
function(callback) { ... },
function(callback) { ... }
], function(err, results) {
// optional callback
});
async.series([
function(callback) { ... },
function(callback) { ... }
]);
시리즈 직렬series 의 역할 은 순서대로 집행 하 는 것 이다.
async.series([
function(callback) {
setTimeout(function() {
callback(null, 1)
}, 2000);
},
function(callback) {
callback(null, 2);
}],
function(err, results) {
console.log(results);
});
출력 결과[ 1, 2 ]
series 함수 의 첫 번 째 매개 변 수 는 하나의 배열 일 수도 있 고 JSON 대상 일 수도 있 습 니 다.매개 변수 유형 이 다 르 고 데 이 터 를 되 돌려 주 는 형식 에 영향 을 줍 니 다.
async.series({
one: function(callback){
callback(null, 1);
},
two: function(callback){
callback(null, 2);
}
},function(err, results) {
console.log(results);
});
출력{one: 1, two: 2}
폭포
waterfall 과 series 함 수 는 모두 순서대로 실 행 됩 니 다.다른 점 은 waterfall 의 모든 함수 가 발생 하 는 값 은 다음 함수 에 전달 할 수 있 습 니 다.series 는 안 됩 니 다.
async.waterfall([
function(callback) {
callback(null, 'one', 'two');
},
function(arg1, arg2, callback) {
// arg1 now equals 'one' and arg2 now equals 'two'
console.log('function 2')
console.log('arg1: ' + arg1)
console.log('arg2: ' + arg2)
callback(null, 'three');
},
function(arg1, callback) {
console.log('function 3')
console.log('arg1: ' + arg1)
// arg1 now equals 'three'
callback(null, 'done');
}
], function(err, result) {
// result now equals 'done'
console.log(result);
});
출력function 2
arg1: one
arg2: two
function 3
arg1: three
done
waterfall 의 첫 번 째 매개 변 수 는 수조 일 수 있 습 니 다.중간 에 함수 가 잘못 되 었 을 때 err 는 최종 callback 에 직접 전 달 했 고 결 과 는 버 려 졌 으 며 뒤의 함 수 는 더 이상 실행 되 지 않 았 습 니 다.
parallel(tasks, [callback])
paraller 함 수 는 여러 함 수 를 병행 하여 실행 합 니 다.모든 함 수 는 즉시 실 행 됩 니 다.다른 함수 가 먼저 실 행 될 때 까지 기다 릴 필요 가 없습니다.
최종 콜백 에 전 달 된 배열 의 데 이 터 는 완 료 된 순서 가 아 닌 tasks 에서 설명 한 순서 입 니 다.
async.parallel([
function(callback){
callback(null, 'one');
},
function(callback){
callback(null, 'two');
}
],
function(err, results){
});
tasks 매개 변 수 는 하나의 배열 이나 json 대상 일 수 있 습 니 다.series 함수 와 마찬가지 로 tasks 매개 변수 유형 이 다 르 고 되 돌아 오 는 results 형식 이 다 를 수 있 습 니 다.예제 에서 tasks 의 리 셋 함 수 를 setTimeout 으로 1000 밀리초 후에 호출 한 다음 에 parallel 의 리 셋 함수 에서 results 를 출력 하여 전체 과정 이 1s 가 걸 렸 는 지 2s 가 걸 렸 는 지 살 펴 보 세 요.
var async=require("async");
async.parallel([
function(callback){
setTimeout(function(){
callback(null, 'one')
},1000);
},
function(callback){
setTimeout(function(){
callback(null, 'two')
},1000);
}
],
function(err, results){
console.log(results);
});
parallelLimit(tasks, limit, [callback])parallel Limit 함 수 는 parallel 과 유사 하지만 매개 변수 limit 가 하나 더 생 겼 습 니 다.limit 매개 변수 제한 작업 은 일정한 수량 만 동시에 동시 다발 할 수 있 습 니 다.무제 한 동시 다발 이 아 닙 니 다.예 는 다음 과 같 습 니 다.
async.parallelLimit([
function(callback){
callback(null, 'one');
},
function(callback){
callback(null, 'two');
}
],
2,
function(err, results){
});
예제 에서 tasks 의 리 셋 함 수 를 setTimeout 으로 1000 밀리초 후에 호출 합 니 다.limit 매개 변 수 를 1 로 설정 한 다음 에 paralleLimit 의 리 셋 함수 에서 results 를 출력 합 니 다.전체 과정 이 1s 가 걸 렸 는 지 2s 가 걸 렸 는 지 확인 하 십시오.
var async=require("async");
async.parallelLimit([
function(callback){
setTimeout(function(){
callback(null, 'one');
}, 1000);
},
function(callback){
setTimeout(function(){
callback(null, 'two');
}, 1000);
}
],
1,
function(err, results){
console.log(results);
});
map(coll, iteratee, callbackopt)map 함수 가 들 어 오 는 배열 을 옮 겨 다 니 며 같은 작업 을 수행 하고 결 과 를 되 돌려 줍 니 다.
cool:배열
iteratee:배열 마다 실행 할 함수
callbackopt:리 셋 함수
async.map([1, 2, 3, 4, 5],
function(item, callback) {
callback(null, item + 5)
},
function(err, result) {
console.log(result)
})
[ 6, 7, 8, 9, 10 ]이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
Javascript에서 Math.max와 Math.max.apply의 차이점과 용법 상세 설명최근에 작은 사례를 만들 때 Math를 만났어요.max.apply라는 용법은 이전에 보기 드물게 재미있게 느껴졌으니 기록해 보세요. 1Math.max 문법:Math.max(n1,n2,n3,...,nX)반환값:max(...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.