📜  JavaScript Reflect Construct()方法

📅  最后修改于: 2020-10-25 11:50:36             🧑  作者: Mango

JavaScript Reflect.construct()方法

静态Reflect.construct()方法允许使用可变数量的参数来调用构造函数。它还提供了添加的选项来指定其他原型。

句法

Reflect.construct(target, argumentsList[, newTarget])

参数

target:是要调用的目标函数。

argumentsList:这是一个类似数组的对象,它指定应调用目标的参数。

newTarget:这是一个应使用其原型的构造方法。另请参见new.target运算符。如果不存在newTarget,它将被视为目标。

返回

此方法返回目标的新实例(如果存在,则返回newTarget),并由目标初始化为具有给定参数的构造函数。

异常处理

如果target或newTarget不是构造函数,则此异常将引发TypeError。

例子1

const a = new Array(1,2,3);
const b = Reflect.construct ( Array, [1,2,3] );
console.log(a);
console.log(b);

输出:

 [1, 2, 3]
 [1, 2, 3]

例子2

function func1(a, b, c) {
  this.sum = a + b + c;
}
const args = [1, 2, 3];
const object1 = new func1(...args);
console.log(object1.sum);

输出:

 6

例子3

function func1(a, b, c) {
  this.sum = a + b + c;
}
function func2(a, b, c) {
  this.sum = a + b + c;
}
const args2 = [1, 4, 3];
const args = [1, 2, 3];
const object1 = new func1(...args);
const object2 = Reflect.construct(func2, args2);
console.log(object2.sum);
console.log(object1.sum);

输出:

8
 6