我有一个看起来像这样的箭头函数(简化):
const f = arg => { arg.toUpperCase(); };
但是当我调用它时,我得到undefined
:
console.log(f("testing")); // undefined
为什么?
例子:
(注意:对于上述箭头函数的特定问题,这是一个干净、规范的重复目标。)
我有一个看起来像这样的箭头函数(简化):
const f = arg => { arg.toUpperCase(); };
但是当我调用它时,我得到undefined
:
console.log(f("testing")); // undefined
为什么?
例子:
(注意:对于上述箭头函数的特定问题,这是一个干净、规范的重复目标。)
当您使用箭头函数的函数体版本(带有{}
)时,没有隐含的return
. 你必须指定它。当您使用简洁的正文 (no {}
) 时,正文表达式的结果由函数隐式返回。
所以你可以用一个显式来写return
:
const f = arg => { return arg.toUpperCase(); };
// Explicit return ^^^^^^
或简洁的正文:
const f = arg => arg.toUpperCase();
例子:
有点相切,但说到{}
:如果您希望简洁箭头的主体表达式成为对象初始值设定项,请将其放入()
:
const f = arg => ({prop: arg.toUpperCase()});