Reflect.apply()
The Reflect.apply() static method calls a target function with arguments as specified.
Try it
Syntax
js
Reflect.apply(target, thisArgument, argumentsList)
Parameters
target-
The target function to call.
thisArgument-
The value of
thisprovided for the call totarget. argumentsList-
An array-like object specifying the arguments with which
targetshould be called.
Return value
The result of calling the given target function with the specified this value and arguments.
Exceptions
TypeError-
Thrown if
targetis not a function orargumentsListis not an object.
Description
Reflect.apply() provides the reflective semantic of a function call. That is, Reflect.apply(target, thisArgument, argumentsList) is semantically equivalent to:
js
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 thetargetparameter instead of thethiscontext.Reflect.apply()throws ifargumentsListis omitted instead of defaulting to calling with no parameters.
Reflect.apply() invokes the [[Call]] object internal method of target.
Examples
Using Reflect.apply()
js
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"
Specifications
| Specification |
|---|
| ECMAScript Language Specification # sec-reflect.apply |
Browser compatibility
BCD tables only load in the browser