JS 비동기 프로 그래 밍 수기
Promise 대상 은 비동기 작업 을 대표 합 니 다. 세 가지 상태 가 있 습 니 다. Pending (진행 중), Resolved (완료 되 었 습 니 다. Fulfilled) 와 Rejected (실패) 입 니 다.
기본 용법
var promise = new Promise(function(resolve, reject) {
// ... some code
if (/* */){
resolve(value);
} else {
reject(error);
}
}).then(function(value) {
// success
}, function(error) {
// failure
});;
Promise 구조 함 수 는 하나의 함 수 를 매개 변수 로 받 아들 이 는데 이 함수 의 두 매개 변 수 는 각각
resolve
과 reject
이다.then 방법 은 두 개의 반전 함 수 를 매개 변수 로 받 아들 일 수 있 습 니 다.첫 번 째 리 셋 함 수 는 Promise 대상 의 상태 가 Resolved 로 바 뀌 었 을 때 호출 되 고, 두 번 째 리 셋 함 수 는 Promise 대상 의 상태 가 Reject 로 바 뀌 었 을 때 호출 됩 니 다.그 중에서 두 번 째 함 수 는 선택 할 수 있 는 것 이 므 로 반드시 제공 해 야 하 는 것 은 아니다.이 두 함 수 는 모두 Promise 대상 이 전달 하 는 값 을 매개 변수 로 받 아들 입 니 다.
then 방법 은 새로운 Promise 인 스 턴 스 를 되 돌려 줍 니 다.따라서 체인 식 표기 법, 즉 then 방법 뒤에 다른 then 방법 을 호출 할 수 있다.
Promise.prototype.catch()
Promise. prototype. catch 방법 은. then (null, rejection) 의 별명 으로 오류 가 발생 했 을 때의 반전 함 수 를 지정 합 니 다.
getJSON("/posts.json").then(function(posts) {
// ...
}).catch(function(error) {
// getJSON
console.log(' !', error);
});
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
다양한 언어의 JSONJSON은 Javascript 표기법을 사용하여 데이터 구조를 레이아웃하는 데이터 형식입니다. 그러나 Javascript가 코드에서 이러한 구조를 나타낼 수 있는 유일한 언어는 아닙니다. 저는 일반적으로 '객체'{}...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.