The Reflect.apply()
static method calls a target function with arguments as specified.
Syntax
Reflect.apply(target, thisArgument, argumentsList)
Parameters
target
- : The target function to call.
thisArgument
- : The value of
this
provided for the call totarget
.
- : The value of
argumentsList
- : An array-like object specifying the arguments with which
target
should be called.
- : An array-like object specifying the arguments with which
Return value
The result of calling the given target
function with the specified this
value and arguments.
Exceptions
- TypeError
- : Thrown if
target
is not a function orargumentsList
is not an object.
- : Thrown if
Description
Reflect.apply()
provides the reflective semantic of a function call. That is, Reflect.apply(target, thisArgument, argumentsList)
is semantically equivalent to:
Math.floor.apply(null, [1.75]);
Reflect.apply(Math.floor, null, [1.75]);
The only differences are:
Reflect.apply()
takes the function to call as thetarget
parameter instead of thethis
context.Reflect.apply()
throws ifargumentsList
is omitted instead of defaulting to calling with no parameters.
Reflect.apply()
invokes the <span class="createlink">Call</span>
object internal method of target
.
Examples
Using Reflect.apply()
Reflect.apply(Math.floor, undefined, [1.75]);
// 1;
Reflect.apply(String.fromCharCode, undefined, [104, 101, 108, 108, 111]);
// "hello"
Reflect.apply(RegExp.prototype.exec, /ab/, ["confabulation"]).index;
// 4
Reflect.apply("".charAt, "ponies", [3]);
// "i"