ES6-async 함수
const fs=require('fs');
const readFile=function(fileName){
return new Promise(function(resolve,reject){
fs.readFile(fileName,function(error,data){
if(error)return reject(error);
resolve(data);
})
})
};
const gen = function* () {
const f1 = yield readFile('/etc/fstab');
const f2 = yield readFile('/etc/shells');
console.log(f1.toString());
console.log(f2.toString());
};
위 코드의 함수gen은 async 함수로 쓸 수 있다.바로 아래가 이렇다.
const asyncReadFile = async function () {
const f1 = await readFile('/etc/fstab');
const f2 = await readFile('/etc/shells');
console.log(f1.toString());
console.log(f2.toString());
};
비교해 보면 async 함수는 Generator 함수의 별표를 async로 바꾸고 yield를 await로 바꾸는 것이다.
async 함수에 대한Generator 함수의 개선, 네 가지 구현
asyncReadFile();
위의 코드는 asyncReadFile 함수를 호출하면 자동으로 실행되고 마지막 결과를 출력합니다.이것은Generator 함수와 전혀 다르기 때문에next 방법을 사용하거나co모듈을 사용해야만 진정으로 실행하고 최종 결과를 얻을 수 있습니다.
(2) 더 좋은 의미.
async와await는 별표와yield보다 의미가 더 명확합니다.async는 함수에 비동기적인 조작이 있음을 나타내고await는 뒤에 바짝 붙어 있는 표현식이 결과를 기다려야 한다는 것을 나타낸다.
(3) 더욱 광범위한 적용성.
co 모듈은 yield 명령 뒤에는 Thunk 함수나 Promise 대상만 있을 수 있고, async 함수의await 명령 뒤에는 Promise 대상과 원시 형식의 값(수치, 문자열, 부울 값만 있을 수 있지만, 이때는 즉시resolved의 Promise 대상으로 자동으로 바뀐다고 약정합니다.
(4) 반환 값은 Promise입니다.
async 함수의 반환값은 Promise 대상입니다. 이것은Generator 함수의 반환값이Iterator 대상보다 훨씬 편리합니다.다음 동작을 then 방법으로 지정할 수 있습니다.
더 나아가 async 함수는 여러 개의 비동기 조작으로 포장된 Promise 대상으로 볼 수 있고await 명령은 내부 then 명령의 문법 설탕이다
2: 기본 사용법;
async 함수는 Promise 객체를 반환합니다.then 방법으로 리셋 함수를 추가할 수 있습니다.함수가 실행될 때await를 만나면 먼저 되돌아옵니다.비동기 조작이 완성된 것과 같다.함수 체내 뒤의 문장을 이어서 실행하기;
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.