Reflect.get()

Baseline 已广泛支持

此特性已非常成熟,可在多种设备和浏览器版本上使用。自 ⁨2016 年 9 月⁩以来,它已在各大浏览器中可用。

Reflect.get() 静态方法类似于属性访问器语法,但它是一个函数。

试一试

const object = {
  x: 1,
  y: 2,
};

console.log(Reflect.get(object, "x"));
// Expected output: 1

const array = ["zero", "one"];

console.log(Reflect.get(array, 1));
// Expected output: "one"

语法

js
Reflect.get(target, propertyKey)
Reflect.get(target, propertyKey, receiver)

参数

目标

要获取属性的目标对象。

propertyKey

要获取的属性名称。

receiver 可选

如果遇到 getter,则在调用 target 时提供给 this 的值。

返回值

属性的值。

异常

TypeError

如果 target 不是一个对象,则抛出。

描述

Reflect.get() 提供了属性访问的反射语义。也就是说,Reflect.get(target, propertyKey, receiver) 在语义上等同于

js
target[propertyKey];

请注意,在正常的属性访问中,targetreceiver 在可观察上是相同的对象。

Reflect.get() 调用 target[[Get]] 对象内部方法

示例

使用 Reflect.get()

js
// Object
const obj1 = { x: 1, y: 2 };
Reflect.get(obj1, "x"); // 1

// Array
Reflect.get(["zero", "one"], 1); // "one"

// Proxy with a get handler
const obj2 = new Proxy(
  { p: 1 },
  {
    get(t, k, r) {
      return `${k}bar`;
    },
  },
);
Reflect.get(obj2, "foo"); // "foobar"

// Proxy with get handler and receiver
const obj3 = new Proxy(
  { p: 1, foo: 2 },
  {
    get(t, prop, receiver) {
      return `${receiver[prop]}bar`;
    },
  },
);
Reflect.get(obj3, "foo", { foo: 3 }); // "3bar"

规范

规范
ECMAScript® 2026 语言规范
# sec-reflect.get

浏览器兼容性

另见