举例写文章详情页面的时候的一个场景:首先更改文章详情中的 PV,然后读取文章详情,然后根据文章详情中文章 Id 查阅该文章评论和该文章作者信息。获取全部数据之后渲染文章详情页。数据库操作都是异步的,最直接想到的办法就是一层一层的回调函数,问题出来了:十分不雅观,要是层再多一点还会有更多麻烦。怎么解决?业内为了处理异步操作问题也是拼了,什么async,q,bluebird,co,处理方式不同,各有千秋,感兴趣可以了解一下,但是惊喜的发现nodejs 7.6已经默认支持ES7中的 async/await 了,结合ES6中的 promise对象,用起来不亦乐乎的。
Async/await的主要益处是可以避免回调地狱(callback hell)问题。
基本概念:
async 表示这是一个async函数,await只能用在这个函数里面。
await 表示在这里等待promise返回结果了,再继续执行。
await 后面跟着的应该是一个promise对象(当然,其他返回值也没关系,不过那样就没有意义了…)
举例:
获取返回值:
捕捉错误:
错误
// 所以以下<a href="https://www.jb51.cc/tag/daima/" target="_blank" class="keywords">代码</a>不会被执行了
console.log('end');
} catch (err) {
console.log(err); // 这里捕捉到错误 error
}
};
在循环中:
再循环中使用不需要闭包,每次循环会被阻塞。
最前面提到的场景:(综合使用)
获取文章信息
await new Promise(function (resolve,reject) {
userModel.getUserById(post.author,function (author) {
post.author=author;
resolve();
})
});//获取文章作者
var comments = await new Promise(function (resolve,reject) {
CommentModel.getComments(post._id,function (comment) {
resolve(comment);
});
});// 获取该文章所有留言
for(var i=0;i获取文章留言作者
}
if (!post) {
req.session.error = '该文章不存在';
return res.redirect('/post');
}
res.render('post',{post: post,comments: comments});
};
showArticle();
以上所述是小编给大家介绍的async/await与promise(nodejs中的异步操作问题)。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持。
原文链接:https://www.f2er.com/nodejs/41115.html