프로미스 체인의 종속 결과를 처리하는 방법
귀하의 질문은 일련의 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!