为什么JavaScript/ES6中不能使用带箭头函数的`new`? [英] Why can I not use `new` with an arrow function in JavaScript/ES6?
本文介绍了为什么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。
这篇关于为什么JavaScript/ES6中不能使用带箭头函数的`new`?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!
查看全文