javascript - 為什么嵌套的Promise不能按預(yù)期捕獲Exception?
問題描述
我有如下的代碼,本來期望‘core exception’ 可以被 ‘立即執(zhí)行的函數(shù)(見最后)’捕獲到,并打印出“Got it in main scope”,但沒有按預(yù)期執(zhí)行,即'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'); }})();
程序運行結(jié)果為
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的參數(shù)的返回值是被無視的// 加個async不會導(dǎo)致新Promise被連接到fulfill或reject// 所以下面的那個Promise不會被then或catch,成為你看到的現(xiàn)象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:為什么我只有做如下的修改,才能得到預(yù)期的結(jié)果呢? 是不是和microtask有關(guān)呢?誰能幫忙清楚地解釋一下?
’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'); }})();
得到的運行結(jié)果為:
wrapper exception risescore promise rejected - core exception risesmain exception propagatedGot it in main scope回答4:
<script>alert(‘s’)</script>
相關(guān)文章:
1. android - 優(yōu)酷的安卓及蘋果app還在使用flash技術(shù)嗎?2. android - 使用百度sdk調(diào)用SDKInitializer.initialize(this)時報錯?3. javascript - webpack-dev-server和webpack沖突嗎4. javascript - 最近用echarts做統(tǒng)計圖時遇到兩個問題!!5. css3 - img垂直水平居中問題6. html5 - 用h5本地存儲是否安全?7. javascript - 使用百度文本編輯器ueditor不顯示樣式問題8. 微信公眾號在線生成二維碼帶參數(shù)怎么搞?9. javascript - react熱加載的一段代碼10. java中double類型轉(zhuǎn)換為String類型?

網(wǎng)公網(wǎng)安備