您好,登錄后才能下訂單哦!
這篇文章給大家分享的是有關如何解決nodejs中的異步操作問題的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
基本概念:
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();
感謝各位的閱讀!關于“如何解決nodejs中的異步操作問題”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。