为什么JavaScript/ES6中不能使用带箭头函数的`new`?

据我所知,箭头函数类似于普通函数。这样使用没有问题:

let X = () => {};
let Y = function() {};
X();
Y();

但是,当我将它们与new

一起使用时出现错误
let X = () => {};
let Y = function() {};
x = new X();
y = new Y();

Uncaught TypeError: X is not a constructor

为什么?


解决方案

Q.我做错了什么?

A.您将new与箭头函数一起使用,这是不允许的。

q.能否将箭头函数转换为构造函数?

A.仅将其包装在普通函数中,这将是愚蠢的。 不能将箭头函数本身转换为构造函数。

Q.您能解释一下规范如何禁止new使用箭头函数吗?

A.要成为构造函数,函数对象必须具有 A[[Construct]] 内部方法。

使用function创建的函数 关键字是构造函数,一些内置函数也是如此 例如Date。这些是您可以与new一起使用的函数。

其他函数对象没有[[Construct]] 内部方法。其中包括箭头函数。所以你不能 对这些使用new。这是有意义的,因为您无法设置 箭头函数的this值。

一些内置函数也不是构造函数。例如你 无法执行new parseInt()

问:您能解释一下禁止new的原因吗 是否在规范中使用箭头函数?

A.使用常识,或搜索es-discuss archives。

相关文章