舉例寫文章詳情頁面的時候的一個場景:首先更改文章詳情中的 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對象(當然,其他返回值也沒關系,不過那樣就沒有意義了…)
舉例:
獲取返回值:
var sleep = function (time) { return new Promise(function (resolve, reject) { setTimeout(function () { // 返回 ‘ok' resolve('ok'); }, time); })};var start = async function () { let result = await sleep(3000); console.log(result); // 收到 ‘ok'};捕捉錯誤:
var sleep = function (time) { return new Promise(function (resolve, reject) { setTimeout(function () { // 模擬出錯了,返回 ‘error' reject('error'); }, time); })};var start = async function () { try { console.log('start'); await sleep(3000); // 這里得到了一個返回錯誤 // 所以以下代碼不會被執行了 console.log('end'); } catch (err) { console.log(err); // 這里捕捉到錯誤 `error` }};在循環中:
var start = async function () { for (var i = 1; i <= 10; i++) { console.log(`當前是第${i}次等待..`); await sleep(1000); }};再循環中使用不需要閉包,每次循環會被阻塞。
最前面提到的場景:(綜合使用)
var showArticle = async function () { await new Promise(function (resolve, reject) { PostModel.incPv(postId, function (result) { resolve(result); }); });// pv 加 1 var post = await new Promise(function (resolve, reject) { PostModel.getPostById(postId, function (article) { resolve(article); }); });// 獲取文章信息 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<comments.length;i++){ await new Promise(function (resolve, reject) { userModel.getUserById(comments[i].author,function (author) { comments[i].author=author; resolve(); }) });//獲取文章留言作者 } if (!post) { req.session.error = '該文章不存在'; return res.redirect('/post'); } res.render('post',{post: post, comments: comments}); }; showArticle();以上所述是小編給大家介紹的async/await與promise(nodejs中的異步操作問題),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!
新聞熱點
疑難解答