NodeJS를 사용하여 네트워크 요청 및 약속 작업을 할 때 중첩된 약속이 발생할 수 있습니다. 이것이 본질적으로 잘못된 것은 아니지만 보다 효율적인 흐름을 위해 이러한 Promise를 함께 연결해야 할 수도 있습니다.
제공된 코드 조각은 여러 개의 중첩된 Promise를 사용하여 API 호출을 수행하는 시나리오를 보여줍니다.
exports.viewFile = function(req, res) { var fileId = req.params.id; boxContentRequest('files/' + fileId + '/content', req.user.box.accessToken) .then(function(response) { boxViewerRequest('documents', {url: response.request.href}, 'POST') .then(function(response) { boxViewerRequest('sessions', {document_id: response.body.id}, 'POST') .then(function(response) { console.log(response); }); }); }); };
이러한 약속을 연결하려면 간단한 수정이 필요합니다.
exports.viewFile = function(req, res) { var fileId = req.params.id; boxContentRequest('files/' + fileId + '/content', req.user.box.accessToken) .then(function(response) { return boxViewerRequest('documents', {url: response.request.href}, 'POST'); }) .then(function(response) { return boxViewerRequest('sessions', {document_id: response.body.id}, 'POST'); }) .then(function(response) { console.log(response); }); };
이 접근 방식의 핵심은 다음과 같습니다. return 각 then 콜백에서 새 Promise를 반환합니다.
.then(function(response) { return nextPromise; })
이는 Promise 체인이 계속되고 "내부" Promise의 값으로 해결되도록 보장합니다. 이러한 Promise를 연결하면 더 읽기 쉽고 유지 관리하기 쉬운 코드베이스를 만들 수 있습니다.
위 내용은 네트워크 요청에 대해 NodeJS에서 중첩된 약속을 어떻게 간소화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!