>웹 프론트엔드 >JS 튜토리얼 >JavaScript Promise Chain에서 종속 결과를 관리하는 방법은 무엇입니까?

JavaScript Promise Chain에서 종속 결과를 관리하는 방법은 무엇입니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-05 18:01:11885검색

How to Manage Dependent Results in JavaScript Promise Chains?

프로미스 체인의 종속 결과를 처리하는 방법

귀하의 질문은 일련의 Promise 기반 HTTP 요청 내에서 이전 결과를 활용하는 방법에 관한 것입니다. 이 문제를 해결하기 위해 먼저 종속 Promise에서 데이터를 공유하기 위한 다양한 전략을 고려해 보겠습니다. 전략 선택은 모든 이전 결과에 액세스해야 하는지 아니면 가장 최근 결과에만 액세스해야 하는지에 따라 달라집니다.

결과를 순차적으로 공급

이 모델에서는 각 결과 요청은 다음 인수로 전달됩니다. 그러나 이전 결과에 액세스하는 것은 어려워집니다.

결과를 더 높은 범위에 할당

또는 결과를 더 높은 범위의 변수에 저장할 수 있습니다. 이를 통해 이전의 모든 결과에 액세스할 수 있습니다.

객체에 결과 누적

이 접근 방식에는 결과를 축적하기 위한 객체를 생성하는 작업이 포함됩니다. 각 요청은 해당 결과를 객체에 추가하여 이전의 모든 데이터를 사용할 수 있게 만듭니다.

중첩된 약속 체인

중첩된 약속은 이전 결과에 대한 액세스를 유지합니다. 각 연속 레이어는 이전의 모든 결과에 액세스할 수 있는 범위를 제공합니다.

Promise.all()을 사용하여 체인 끊기

일부 요청이 독립적으로 작동할 수 있는 경우 다음을 사용할 수 있습니다. Promise.all()은 완료될 때까지 기다립니다. 이를 통해 결과를 비동기적으로 얻을 수 있습니다.

ES7에서 Async/Await 사용

ES7에서 async/await는 비동기 작업의 순서를 단순화할 수 있습니다. 동일한 범위 내에서 결과를 사용할 수 있으므로 여러 .then() 핸들러가 필요하지 않습니다.

예제에 적용

특정 사례의 경우 API 키 여러 HTTP 요청 간에 전달되는 경우 다음을 수행할 수 있습니다.

var r1, r2, r3;
callhttp("172.16.28.200", payload).then(function(result1) {
     r1 = result1.data; // Extract the API key
     return callhttp("172.16.28.200", payload);
}).then(function(result2) {
     r2 = result2.data;
     // r1 contains the API key from the previous request
     return callhttp("172.16.28.200", payload);
}).then(function(result3) {
     r3 = result3.data;
     // r1 and r2 contain the API keys from the previous requests
});

위 내용은 JavaScript Promise Chain에서 종속 결과를 관리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.