亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術文章
文章詳情頁

javascript - node中Promise也被嵌套了

瀏覽:212日期:2023-09-06 08:48:25

問題描述

1.

假如有兩個mongodb集合,一個是users,一個是posts,在posts列表中展示對應的users信息,常規異步處理嵌套太多.就使用Promise來解決,發現,promise解決時也有一個問題.

2. 解決代碼如下

//封裝查詢一條函數findOneData = function(db, colName, data) { return new Promise(function(reslove, reject) {db.collection(colName).find(data).toArray(function(err, data) { if (err) {console.log('數據查詢錯誤' + err);reject(err);return; } reslove({ db: db, data: data });}); });};db_conn() .then(function(db) {return findOneData(db, 'test', {}); }) .then(function(data) {console.log(data); });

這樣的方法是否正確?貌似是解決了,但是總感覺哪里不對,,,

問題解答

回答1:

promise不是最終解決方案也不見得比回調優雅多少 async/await才是

回答2:

有三點,直接把上面的代碼寫在db_conn的then里面,然后返回this.在最外層統一使用catch捕捉異常。將console.log給刪了,看起來怪怪的,

回答3:

db_conn().then(db=>{return { db:db, test:’test’, data:{} }}).then(findOneData).then(r=>{ console.log(r);});

最后把你的findOneData改一下接收參數的方式,是不是好點了?

回答4:

db_conn() .then(db => findOneData(db, 'test', {})) .then(data => console.log(data));

這樣看起來是不是要順眼些?

(async function() { const db = await db_conn(); const data = await findOneData(db, 'test', {}); console.log(data);})();

這樣是不是更順眼些?

回答5:

Promise 方案是在不增加語言元素的基礎上解決異步回調的問題,所以必然存在一些局限性。

在原有的回調之上,Promise 至少會增加一層回調,所以在原回調鏈很短的情況下,比如題主的情況,只有一層,看起來用 Promise 似乎并無優勢,這也是正常的。

如果遇到更復雜的情況,更多層次的嵌套,就能看出用 Promise 的價值了。

樓上各位都提供了很好的寫法,我就不多說了。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 久草久草久草 | 亚洲天堂免费视频 | 成人影院免费看 | 久草福利资源网站免费 | 看三级毛片 | 国产永久免费视频m3u8 | 欧美在线一级va免费观看 | 欧美精品18videos性欧美 | 国产精品黄在线观看观看 | 欧美性精品hd在线观看 | 国产三级a三级三级天天 | 亚洲精品午夜一区二区在线观看 | 美女被靠视频免费网站不需要会员 | 国产精品高清免费网站 | 97在线视频免费 | 日本护士视频xxxxxwww | 国产精品深爱在线 | 国产精品免费大片一区二区 | 欧美日韩在线第一页 | 中文国产日韩欧美视频 | 国产成人综合久久精品亚洲 | 欧美 日韩 国产 成人 在线观看 | 欧美黄网在线 | 国产看片视频 | 国产欧美日韩成人 | 欧美一级在线全免费 | 久久精品操 | 国产视频二 | 亚洲欧美视频一区 | 免费人成年短视频在线观看免费网站 | 日韩特黄特色大片免费视频 | 国产亚洲精品免费 | 国产成人高清精品免费软件 | 国产一区二区免费在线观看 | 国产精品_国产精品_国产精品 | 真人一级毛片免费完整视 | 亚洲人妖女同在线播放 | 欧美激情国产一区在线不卡 | 成人综合在线观看 | 91香蕉成人免费高清网站 | 成人在线黄色 |