Reflect.getOwnPropertyDescriptor()

Baseline 已广泛支持

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

Reflect.getOwnPropertyDescriptor() 静态方法与 Object.getOwnPropertyDescriptor() 类似。如果给定属性存在于对象上,它将返回该属性的属性描述符;否则,返回 undefined

试一试

const object = {
  property1: 42,
};

console.log(Reflect.getOwnPropertyDescriptor(object, "property1").value);
// Expected output: 42

console.log(Reflect.getOwnPropertyDescriptor(object, "property2"));
// Expected output: undefined

console.log(Reflect.getOwnPropertyDescriptor(object, "property1").writable);
// Expected output: true

语法

js
Reflect.getOwnPropertyDescriptor(target, propertyKey)

参数

目标

要在其中查找属性的目标对象。

propertyKey

要获取自有属性描述符的属性名称。

返回值

如果属性作为 target 的自有属性存在,则返回一个属性描述符对象;否则,返回 undefined

异常

TypeError

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

描述

Reflect.getOwnPropertyDescriptor() 提供了检索对象属性描述符的反射语义。与 Object.getOwnPropertyDescriptor() 的唯一区别在于如何处理非对象目标。如果目标不是对象,Reflect.getOwnPropertyDescriptor() 会抛出 TypeError,而 Object.getOwnPropertyDescriptor() 会将其强制转换为对象。

Reflect.getOwnPropertyDescriptor() 调用 target[[GetOwnProperty]] 对象内部方法

示例

使用 Reflect.getOwnPropertyDescriptor()

js
Reflect.getOwnPropertyDescriptor({ x: "hello" }, "x");
// {value: "hello", writable: true, enumerable: true, configurable: true}

Reflect.getOwnPropertyDescriptor({ x: "hello" }, "y");
// undefined

Reflect.getOwnPropertyDescriptor([], "length");
// {value: 0, writable: true, enumerable: false, configurable: false}

与 Object.getOwnPropertyDescriptor() 的区别

如果此方法的 target 参数不是对象(而是原始值),则会引发 TypeError。使用 Object.getOwnPropertyDescriptor 时,非对象第一个参数首先会被强制转换为对象。

js
Reflect.getOwnPropertyDescriptor("foo", 0);
// TypeError: "foo" is not non-null object

Object.getOwnPropertyDescriptor("foo", 0);
// { value: "f", writable: false, enumerable: true, configurable: false }

规范

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

浏览器兼容性

另见