龙都娱乐»前端»try-catch-finally,被你忽略掉的执行顺序

try-catch-finally,被你忽略掉的执行顺序

来源:原罪 发布时间:2018-06-15 阅读次数:
try-catch是捕捉异常的神器,不管是调试还是防止软件崩溃,都离不开它。今天笔者介绍一下加上finally后的执行顺序 function test() { try { console.log(1); } finally { console.log(2); } } console.log(test()); // 1 2 嗯!按顺序执行了。
我们在try中加入return语句 function test() { try { console.log(1); return 'from_try'; } catch (e) { // TODO } finally { console.log(2); } } console.log(test()); // 1 2 from_try 等等,难道不应该是 1 > from_try > 2的顺序吗?
抱歉啊,是这样的,在try和catch的代码块中,如果碰到return语句,那么在return之前,会先执行finally中的内容,所以2会比from_try优先输出。

我们在finally中也加入return语句 function test() { try { console.log(1); return 'from_try'; } catch (e) { // TODO } finally { console.log(2); return 'from_finally'; } } console.log(test()); // 1 2 from_finally 买噶的,我的from_try怎么不见了?
抱歉,按照上一条的规则,finally是会优先执行的,所以如果finally里有return语句,那么就真的return了。

现在笔者在try语句块中故意报错 function test() { try { console.log(1); throw new Error('throw'); } catch (e) { console.log(e.message); return 'from_catch'; } finally { console.log(2); } } console.log(test()); // 1 throw 2 from_catch 看来,try和catch的return都需要先经过finally。

结语

只是一个很小的细节。但也希望各位看官好好利用这种特性。
QQ群:WEB龙都娱乐官方群(515171538),验证消息:10000
微信群:加小编微信 849023636 邀请您加入,验证消息:10000
提示:更多精彩内容关注微信公众号:全栈龙都娱乐中心(fsder-com)
网友评论(共0条评论) 正在载入评论......
理智评论文明上网,拒绝恶意谩骂 发表评论 / 共0条评论
登录会员中心
龙都娱乐