试一试
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];
请注意,在正常的属性访问中,target 和 receiver 在可观察上是相同的对象。
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 |
浏览器兼容性
加载中…