Skip to content

26 Reflection

26.1 The Reflect Object

The Reflect object:

  • is the intrinsic object %Reflect%.
  • is the initial value of the Reflect property of the global object.
  • is an ordinary object.
  • has a [[Prototype]] internal slot whose value is the intrinsic object %ObjectPrototype%.
  • is not a function object.
  • does not have a [[Construct]] internal method; it cannot be used as a constructor with the new operator.
  • does not have a [[Call]] internal method; it cannot be invoked as a function.

26.1.1 Reflect.apply ( target, thisArgument, argumentsList )

When the apply function is called with arguments target, thisArgument, and argumentsList, the following steps are taken:

  1. If IsCallable(target) is false, throw a TypeError exception.
  2. Let args be ? CreateListFromArrayLike(argumentsList).
  3. Perform PrepareForTailCall().
  4. Return ? Call(target, thisArgument, args).

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

When the construct function is called with arguments target, argumentsList, and newTarget, the following steps are taken:

  1. If IsConstructor(target) is false, throw a TypeError exception.
  2. If newTarget is not present, let newTarget be target.
  3. Else if IsConstructor(newTarget) is false, throw a TypeError exception.
  4. Let args be ? CreateListFromArrayLike(argumentsList).
  5. Return ? Construct(target, args, newTarget).

26.1.3 Reflect.defineProperty ( target, propertyKey, attributes )

When the defineProperty function is called with arguments target, propertyKey, and attributes, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Let key be ? ToPropertyKey(propertyKey).
  3. Let desc be ? ToPropertyDescriptor(attributes).
  4. Return ? target.[[DefineOwnProperty]](key, desc).

26.1.4 Reflect.deleteProperty ( target, propertyKey )

When the deleteProperty function is called with arguments target and propertyKey, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Let key be ? ToPropertyKey(propertyKey).
  3. Return ? target.[[Delete]](key).

26.1.5 Reflect.get ( target, propertyKey [ , receiver ] )

When the get function is called with arguments target, propertyKey, and receiver, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Let key be ? ToPropertyKey(propertyKey).
  3. If receiver is not present, then
    1. Let receiver be target.
  4. Return ? target.[[Get]](key, receiver).

26.1.6 Reflect.getOwnPropertyDescriptor ( target, propertyKey )

When the getOwnPropertyDescriptor function is called with arguments target and propertyKey, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Let key be ? ToPropertyKey(propertyKey).
  3. Let desc be ? target.[[GetOwnProperty]](key).
  4. Return FromPropertyDescriptor(desc).

26.1.7 Reflect.getPrototypeOf ( target )

When the getPrototypeOf function is called with argument target, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Return ? target.[[GetPrototypeOf]]().

26.1.8 Reflect.has ( target, propertyKey )

When the has function is called with arguments target and propertyKey, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Let key be ? ToPropertyKey(propertyKey).
  3. Return ? target.[[HasProperty]](key).

26.1.9 Reflect.isExtensible ( target )

When the isExtensible function is called with argument target, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Return ? target.[[IsExtensible]]().

26.1.10 Reflect.ownKeys ( target )

When the ownKeys function is called with argument target, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Let keys be ? target.[[OwnPropertyKeys]]().
  3. Return CreateArrayFromList(keys).

26.1.11 Reflect.preventExtensions ( target )

When the preventExtensions function is called with argument target, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Return ? target.[[PreventExtensions]]().

26.1.12 Reflect.set ( target, propertyKey, V [ , receiver ] )

When the set function is called with arguments target, V, propertyKey, and receiver, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. Let key be ? ToPropertyKey(propertyKey).
  3. If receiver is not present, then
    1. Let receiver be target.
  4. Return ? target.[[Set]](key, V, receiver).

26.1.13 Reflect.setPrototypeOf ( target, proto )

When the setPrototypeOf function is called with arguments target and proto, the following steps are taken:

  1. If Type(target) is not Object, throw a TypeError exception.
  2. If Type(proto) is not Object and proto is not null, throw a TypeError exception.
  3. Return ? target.[[SetPrototypeOf]](proto).

26.2 Proxy Objects

26.2.1 The Proxy Constructor

The Proxy constructor:

  • is the intrinsic object %Proxy%.
  • is the initial value of the Proxy property of the global object.
  • creates and initializes a new proxy exotic object when called as a constructor.
  • is not intended to be called as a function and will throw an exception when called in that manner.

26.2.1.1 Proxy ( target, handler )

When Proxy is called with arguments target and handler performs the following steps:

  1. If NewTarget is undefined, throw a TypeError exception.
  2. Return ? ProxyCreate(target, handler).

26.2.2 Properties of the Proxy Constructor

The Proxy constructor:

  • has a [[Prototype]] internal slot whose value is the intrinsic object %FunctionPrototype%.
  • does not have a prototype property because proxy exotic objects do not have a [[Prototype]] internal slot that requires initialization.
  • has the following properties:

26.2.2.1 Proxy.revocable ( target, handler )

The Proxy.revocable function is used to create a revocable Proxy object. When Proxy.revocable is called with arguments target and handler, the following steps are taken:

  1. Let p be ? ProxyCreate(target, handler).
  2. Let steps be the algorithm steps defined in Proxy Revocation Functions.
  3. Let revoker be CreateBuiltinFunction(steps, « [[RevocableProxy]] »).
  4. Set revoker.[[RevocableProxy]] to p.
  5. Let result be ObjectCreate(%ObjectPrototype%).
  6. Perform CreateDataProperty(result, "proxy", p).
  7. Perform CreateDataProperty(result, "revoke", revoker).
  8. Return result.

26.2.2.1.1 Proxy Revocation Functions

A Proxy revocation function is an anonymous function that has the ability to invalidate a specific Proxy object.

Each Proxy revocation function has a [[RevocableProxy]] internal slot.

When a Proxy revocation function, F, is called, the following steps are taken:

  1. Let p be F.[[RevocableProxy]].
  2. If p is null, return undefined.
  3. Set F.[[RevocableProxy]] to null.
  4. Assert: p is a Proxy object.
  5. Set p.[[ProxyTarget]] to null.
  6. Set p.[[ProxyHandler]] to null.
  7. Return undefined.

The length property of a Proxy revocation function is 0.

26.3 Module Namespace Objects

A Module Namespace Object is a module namespace exotic object that provides runtime property-based access to a module's exported bindings. There is no constructor function for Module Namespace Objects. Instead, such an object is created for each module that is imported by an ImportDeclaration that includes a NameSpaceImport.

In addition to the properties specified in 9.4.6 each Module Namespace Object has the following own property:

26.3.1 @@toStringTag

The initial value of the @@toStringTag property is the String value "Module".

This property has the attributes { [[Writable]]: false, [[Enumerable]]: false, [[Configurable]]: false }.