繁体   English   中英

Babel箭头功能编译成ES5

[英]Babel arrow function compilation into ES5

使用巴别塔我注意到一些有点奇怪的东西。

const app = () => {}应该等于var app = function() {}

Babel返回var app = function app() {}

不,babel是正确的,因为分配给var的箭头函数理论上应该具有与该var的名称相当的name属性,以帮助堆栈跟踪和反射。 查看链接以获取更多信息。 如果它变得陈旧,请快速摘要:

函数的name属性在声明时创建。 函数表达式的name属性是从名称绑定推断出来的:

var foo = function() {};
console.log(foo.name); // foo

箭头函数具有相同的行为:

var foo = () => {};
console.log(foo.name); // foo

因为在ES 2015 / ES 6 babel必须实际添加名称以创建命名函数表达式之前,这实际上没有标准化:

var foo = function foo() {}; // notice it's function *foo* now

支持传统环境。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM