解开嵌套 Promise
在 NodeJS 中处理网络代码并使用 Promise 时,经常会遇到嵌套 Promise。虽然这种结构有时是必要的,但它也可能导致代码混乱且不可读。一种更简洁、更高效的方法是链接 Promise,而不是嵌套它们。
嵌套 Promise 的问题
考虑以下示例:
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); }); }); }); };
此代码片段使用嵌套的 Promise 连续发出三个 API 请求。虽然它功能正常,但它在视觉上混乱且难以理解。
改为链接 Promise
要链接 Promise 而不是嵌套它们,请修改 then 回调以返回下一个Promise:
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); }); };
现在,每个 then 回调都会返回后续的 Promise,有效地将它们“链接”在一起。然后,从每个 Promise 解析的值可用作序列中下一个 then 回调的参数。
通过采用此技术,您可以提高代码的可读性和可维护性,特别是在处理多个 API 请求时.
以上是如何避免 Node.js 中的嵌套 Promise 并提高代码可读性?的详细内容。更多信息请关注PHP中文网其他相关文章!