[英]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.