久久福利_99r_国产日韩在线视频_直接看av的网站_中文欧美日韩_久久一

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

javascript - 為什么嵌套的Promise不能按預期捕獲Exception?

瀏覽:129日期:2023-09-02 18:10:24

問題描述

我有如下的代碼,本來期望‘core exception’ 可以被 ‘立即執行的函數(見最后)’捕獲到,并打印出“Got it in main scope”,但沒有按預期執行,即'Got it in main scope'沒有打印。

’use strict’; function core() { function wrapper() {return new Promise((resolve, reject) => { throw new Error('wrapper exception rises');}); } return new Promise(async (resolve, reject) => {try { await wrapper();} catch(error) { console.error(error.message); throw new Error('core exception rises');} });} (async function() { try {await core(); } catch(error) {console.error(error.message);console.error('Got it in main scope'); }})();

程序運行結果為

wrapper exception rises(node:10093) UnhandledPromiseRejectionWarning: Unhandled promise rejection (rejection id: 3): Error: core exception rises(node:10093) DeprecationWarning: Unhandled promise rejections are deprecated. In the future, promise rejections that are not handled will terminate the Node.js process with a non-zero exit code.

誰幫忙解釋一下?非常感謝!

我使用的是node v7.2.1

問題解答

回答1:

簡化的例子是這樣的:

function core() { return new Promise(async (fulfill, reject) => {// Promise constructor的參數的返回值是被無視的// 加個async不會導致新Promise被連接到fulfill或reject// 所以下面的那個Promise不會被then或catch,成為你看到的現象return Promise.reject(new Error('core exception rises')); });};core();回答2:

改改:

return new Promise(async (resolve, reject) => { try {await wrapper(); } catch(error) {reject(new Error('core exception rises')); }});

或者:

return (async function( ) { try {await wrapper(); } catch(error) {console.error(error.message);throw new Error('core exception rises'); }}());

你代碼的問題是,core exception rises這個地方的Promise既沒有resolve,也沒有reject,所以你要怎樣呢?^^

回答3:

為什么我只有做如下的修改,才能得到預期的結果呢? 是不是和microtask有關呢?誰能幫忙清楚地解釋一下?

’use strict’; function core() { function wrapper() {return new Promise((resolve, reject) => { throw new Error('wrapper exception rises');}); } return new Promise(async (resolve, reject) => {try { await wrapper();} catch(error) { console.error(error.message); //throw new Error('core exception rises'); reject(new Error('core exception rises'));} });} (async function() { try {await core().catch(err => { console.log('core promise rejected - ' + err.message); throw new Error('main exception propagated');}); } catch(error) {console.error(error.message);console.error('Got it in main scope'); }})();

得到的運行結果為:

wrapper exception risescore promise rejected - core exception risesmain exception propagatedGot it in main scope回答4:

<script>alert(‘s’)</script>

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 欧美日韩国产在线看 | 天天干夜夜操 | 精品视频一区二区三区 | 91玖玖| 精品国产青草久久久久福利 | 国产一区二区欧美 | 九九在线国产视频 | 欧美精品网 | 81精品国产乱码久久久久久 | 亚洲中字幕 | 亚洲视频在线观看视频 | 2019亚洲日韩新视频 | 欧美精品乱码久久久久久按摩 | 狼人狠狠干| 久久国内精品 | 精品久久久久久 | 成人在线网址 | 成人自拍视频 | 亚洲成人一区二区三区 | 亚洲视频在线一区 | 成人一级视频 | 美女一区| 91精品国产高清久久久久久久久 | 日韩在线不卡 | 久久69精品久久久久久久电影好 | 激情综合网五月婷婷 | 可以看黄的视频 | 狠狠狠色丁香婷婷综合久久五月 | 亚洲免费国产视频 | 欧美精品久久久 | 久久久久久久久99精品 | 国产精品a久久 | 日本黄色一级电影 | 天天操狠狠操 | 日韩专区中文字幕 | 国产精品二区一区二区aⅴ污介绍 | 久久成人综合 | 亚洲精品一区二区三区蜜桃久 | 久久亚洲视频 | 日韩成人在线免费视频 | 久久夜夜|