Why does a return in `finally` override `try`?(为什么`finally`中的返回会覆盖`try`?)
问题描述
try/catch 块中的 return 语句如何工作?
How does a return statement inside a try/catch block work?
function example() {
try {
return true;
}
finally {
return false;
}
}
我希望这个函数的输出是 true
,但实际上它是 false
!
I'm expecting the output of this function to be true
, but instead it is false
!
推荐答案
最后 always 执行.这就是它的用途,这意味着它的返回值会在您的情况下使用.
Finally always executes. That's what it's for, which means its return value gets used in your case.
您需要更改您的代码,使其更像这样:
You'll want to change your code so it's more like this:
function example() {
var returnState = false; // initialization value is really up to the design
try {
returnState = true;
}
catch {
returnState = false;
}
finally {
return returnState;
}
}
一般来说,你永远不想在一个函数中有多个 return 语句,这样的事情就是原因.
Generally speaking you never want to have more than one return statement in a function, things like this are why.
这篇关于为什么`finally`中的返回会覆盖`try`?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:为什么`finally`中的返回会覆盖`try`?


- Css:将嵌套元素定位在父元素边界之外一点 2022-09-07
- addEventListener 在 IE 11 中不起作用 2022-01-01
- 400或500级别的HTTP响应 2022-01-01
- CSS媒体查询(最大高度)不起作用,但为什么? 2022-01-01
- Quasar 2+Apollo:错误:找不到ID为默认的Apollo客户端。如果您在组件设置之外,请使用ProvideApolloClient() 2022-01-01
- 使用RSelum从网站(报纸档案)中抓取多个网页 2022-09-06
- Fetch API 如何获取响应体? 2022-01-01
- Flexslider 箭头未正确显示 2022-01-01
- 如何使用 JSON 格式的 jQuery AJAX 从 .cfm 页面输出查 2022-01-01
- 失败的 Canvas 360 jquery 插件 2022-01-01