Reflect.get()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2016.
TheReflect.get() static method is like theproperty accessor syntax, but as a function.
In this article
Try it
const object = { x: 1, y: 2,};console.log(Reflect.get(object, "x"));// Expected output: 1const array = ["zero", "one"];console.log(Reflect.get(array, 1));// Expected output: "one"Syntax
Reflect.get(target, propertyKey)Reflect.get(target, propertyKey, receiver)Parameters
targetThe target object on which to get the property.
propertyKeyThe name of the property to get.
receiverOptionalThe value of
thisprovided for the call totargetif a getter is encountered.
Return value
The value of the property.
Exceptions
TypeErrorThrown if
targetis not an object.
Description
Reflect.get() provides the reflective semantic of aproperty access. That is,Reflect.get(target, propertyKey, receiver) is semantically equivalent to:
target[propertyKey];Note that in a normal property access,target andreceiver would observably be the same object.
Reflect.get() invokes the[[Get]]object internal method oftarget.
Examples
>Using Reflect.get()
// Objectconst obj1 = { x: 1, y: 2 };Reflect.get(obj1, "x"); // 1// ArrayReflect.get(["zero", "one"], 1); // "one"// Proxy with a get handlerconst obj2 = new Proxy( { p: 1 }, { get(t, k, r) { return `${k}bar`; }, },);Reflect.get(obj2, "foo"); // "foobar"// Proxy with get handler and receiverconst obj3 = new Proxy( { p: 1, foo: 2 }, { get(t, prop, receiver) { return `${receiver[prop]}bar`; }, },);Reflect.get(obj3, "foo", { foo: 3 }); // "3bar"Specifications
| Specification |
|---|
| ECMAScript® 2026 Language Specification> # sec-reflect.get> |