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

Why can I not use `new` with an arrow function in JavaScript/ES6?(为什么JavaScript/ES6中不能使用带箭头函数的`new`?)

本文介绍了为什么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`?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

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

基础教程推荐