Bei der Arbeit mit Netzwerkanfragen und Versprechen mithilfe von NodeJS kann es sein, dass verschachtelte Versprechen auftreten. Obwohl dies nicht grundsätzlich falsch ist, muss man diese Versprechen möglicherweise miteinander verketten, um den Ablauf effizienter zu gestalten.
Der bereitgestellte Codeausschnitt zeigt ein Szenario, in dem mehrere verschachtelte Versprechen verwendet werden, um API-Aufrufe durchzuführen:
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); }); }); }); };
Um diese Versprechen zu verketten, ist eine einfache Modifikation erforderlich:
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); }); };
Der Schlüssel zu diesem Ansatz ist Zurückgebendas neue Versprechen von jedem Rückruf:
.then(function(response) { return nextPromise; })
Dadurch wird sichergestellt, dass die Versprechenskette fortgesetzt und mit dem Wert des „inneren“ Versprechens aufgelöst wird. Durch die Verkettung dieser Versprechen können Sie eine besser lesbare und wartbare Codebasis erstellen.
Das obige ist der detaillierte Inhalt vonWie kann ich verschachtelte Versprechen in NodeJS für Netzwerkanfragen optimieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!