Promise를 사용하여 이전 결과 연결 및 공유
코드에서 Bluebird Promise 라이브러리를 사용하여 여러 HTTP 요청을 생성하려고 하며 한 요청에서 다음 요청으로 응답 데이터를 전달해야 합니다. 이를 달성하기 위해 여러 전략을 활용하여 이전 결과를 Promise와 연결하고 공유할 수 있습니다.
1. Promise 연결
.then() 핸들러 내에서 Promise를 반환하여 Promise를 연결할 수 있습니다. 이후의 각 .then()은 이전 Promise의 결과를 받습니다. 귀하의 경우 다음과 같이 요청을 연결할 수 있습니다:
callhttp("172.16.28.200", payload).then(function(first) { return callhttp("172.16.28.200", first); }).then(function(second) { return callhttp("172.16.28.200", second); });
2. 결과 누적
또는 모든 결과를 단일 개체에 누적할 수도 있습니다. 결과를 저장할 객체를 생성하고 이를 후속 요청에 인수로 전달합니다.
var results = {}; callhttp("172.16.28.200", payload).then(function(first) { results.first = first; return callhttp("172.16.28.200", first); }).then(function(second) { results.second = second; return callhttp("172.16.28.200", second); }).then(function(third) { results.third = third; });
3. 중첩된 약속
모든 이전 결과에 액세스해야 하는 경우 중첩된 약속을 수행할 수 있습니다. 중첩된 각 Promise는 외부 Promise의 결과에 액세스할 수 있습니다.
callhttp("172.16.28.200", payload).then(function(first) { return callhttp("172.16.28.200", first).then(function(second) { return callhttp("172.16.28.200", second).then(function(third) { // Access all three results here }); }); });
4. 체인 깨기
일부 요청이 독립적으로 진행될 수 있는 경우 체인을 끊고 Promise.all()을 사용하여 모두 완료되면 결과를 수집할 수 있습니다.
var p1 = callhttp("172.16.28.200", payload); var p2 = callhttp("172.16.28.200", payload); var p3 = callhttp("172.16.28.200", payload); Promise.all([p1, p2, p3]).then(function(results) { // All three results are available in the `results` array });
5. async/await 사용(ES7 기능)
ES7에서는 async/await를 사용하여 비동기 작업 순서를 단순화할 수 있습니다. 이를 통해 일반 동기 구문을 사용할 수 있으며 중간 결과는 동일한 범위에서 사용할 수 있습니다.
async function myFunction() { const first = await callhttp("172.16.28.200", payload); const second = await callhttp("172.16.28.200", first); const third = await callhttp("172.16.28.200", second); // Access all three results here } myFunction().then(result => {}).catch(error => {});
위 내용은 Bluebird Promise를 사용하여 여러 HTTP 요청의 결과를 연결하고 공유하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!