为什么我的箭头函数没有返回值?

IT技术 javascript ecmascript-6 arrow-functions
2021-01-29 10:09:23

我有一个看起来像这样的箭头函数(简化):

const f = arg => { arg.toUpperCase(); };

但是当我调用它时,我得到undefined

console.log(f("testing")); // undefined

为什么?

例子:


注意:对于上述箭头函数特定问题,这是一个干净、规范的重复目标。)

1个回答

当您使用箭头函数的函数体版本(带有{})时,没有隐含的return. 你必须指定它。当您使用简洁的正文 (no {}) 时,正文表达式的结果由函数隐式返回。

所以你可以用一个显式来写return

const f = arg => { return arg.toUpperCase(); };
// Explicit return ^^^^^^

或简洁的正文:

const f = arg => arg.toUpperCase();

例子:


有点相切,但说到{}:如果您希望简洁箭头的主体表达式成为对象初始值设定项,请将其放入()

const f = arg => ({prop: arg.toUpperCase()});