async/await與promise(nodejs中的異步操作問(wèn)題)
舉例寫(xiě)文章詳情頁(yè)面的時(shí)候的一個(gè)場(chǎng)景:首先更改文章詳情中的 PV,然后讀取文章詳情,然后根據(jù)文章詳情中文章 Id 查閱該文章評(píng)論和該文章作者信息。獲取全部數(shù)據(jù)之后渲染文章詳情頁(yè)。數(shù)據(jù)庫(kù)操作都是異步的,最直接想到的辦法就是一層一層的回調(diào)函數(shù),問(wèn)題出來(lái)了:十分不雅觀,要是層再多一點(diǎn)還會(huì)有更多麻煩。怎么解決?業(yè)內(nèi)為了處理異步操作問(wèn)題也是拼了,什么async,q,bluebird,co,處理方式不同,各有千秋,感興趣可以了解一下,但是驚喜的發(fā)現(xiàn)nodejs 7.6已經(jīng)默認(rèn)支持ES7中的 async/await 了,結(jié)合ES6中的 promise對(duì)象,用起來(lái)不亦樂(lè)乎的。
Async/await的主要益處是可以避免回調(diào)地獄(callback hell)問(wèn)題。
基本概念:
async 表示這是一個(gè)async函數(shù),await只能用在這個(gè)函數(shù)里面。
await 表示在這里等待promise返回結(jié)果了,再繼續(xù)執(zhí)行。
await 后面跟著的應(yīng)該是一個(gè)promise對(duì)象(當(dāng)然,其他返回值也沒(méi)關(guān)系,不過(guò)那樣就沒(méi)有意義了…)
舉例:
獲取返回值:
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' };
捕捉錯(cuò)誤:
var sleep = function (time) { return new Promise(function (resolve, reject) { setTimeout(function () { // 模擬出錯(cuò)了,返回 ‘error' reject('error'); }, time); }) }; var start = async function () { try { console.log('start'); await sleep(3000); // 這里得到了一個(gè)返回錯(cuò)誤 // 所以以下代碼不會(huì)被執(zhí)行了 console.log('end'); } catch (err) { console.log(err); // 這里捕捉到錯(cuò)誤 `error` } };
在循環(huán)中:
var start = async function () { for (var i = 1; i <= 10; i++) { console.log(`當(dāng)前是第${i}次等待..`); await sleep(1000); } };
再循環(huán)中使用不需要閉包,每次循環(huán)會(huì)被阻塞。
最前面提到的場(chǎng)景:(綜合使用)
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中的異步操作問(wèn)題),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
基于Nodejs實(shí)現(xiàn)文件壓縮和解壓功能
在?windows?系統(tǒng)上面,我們壓縮文件,常常需要安裝一些壓縮軟件才能實(shí)現(xiàn)壓縮,可能有些還存在一些問(wèn)題,所以本文就來(lái)使用Nodejs實(shí)現(xiàn)文件壓縮和解壓功能吧2024-03-03node.js實(shí)現(xiàn)登錄注冊(cè)頁(yè)面
這篇文章主要為大家詳細(xì)介紹了node.js實(shí)現(xiàn)簡(jiǎn)單的登錄注冊(cè)頁(yè)面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-04-04詳解koa2學(xué)習(xí)中使用 async 、await、promise解決異步的問(wèn)題
這篇文章主要介紹了詳解koa2學(xué)習(xí)中使用 async 、await、promise解決異步的問(wèn)題,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-11-11前端如何更好的展示后端返回的十萬(wàn)條數(shù)據(jù)
這篇文章主要為大家介紹了前端如何更好的展示后端返回的十萬(wàn)條數(shù)據(jù),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2021-11-11基于Node.js模板引擎教程-jade速學(xué)與實(shí)戰(zhàn)1
下面小編就為大家?guī)?lái)一篇基于Node.js模板引擎教程-jade速學(xué)與實(shí)戰(zhàn)1。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09