• 首页
  • vue
  • TypeScript
  • JavaScript
  • scss
  • css3
  • html5
  • php
  • MySQL
  • redis
  • jQuery
  • Reflect.getOwnPropertyDescriptor()

    静态方法Reflect.getOwnPropertyDescriptor()undefined

    语法

    Reflect.getOwnPropertyDescriptor(target, propertyKey)
    

    参数

    target
    需要寻找属性的目标对象。
    propertyKey
    获取自己的属性描述符的属性的名称。

    返回值

    如果属性存在于给定的目标对象中,则返回属性描述符;否则,返回undefined

    异常

    抛出一个Object

    描述

    Reflect.getOwnPropertyDescriptor方法返回一个属性描述符,如果给定的属性存在于对象中,否则返回Object.getOwnPropertyDescriptor()的唯一不同在于如何处理非对象目标。

    示例

    使用Reflect.getOwnPropertyDescriptor()

    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()的不同点

    如果该方法的第一个参数不是一个对象(一个原始值),那么将造成Object.getOwnPropertyDescriptor,非对象的第一个参数将被强制转换为一个对象处理。

    Reflect.getOwnPropertyDescriptor("foo", 0);
    // TypeError: "foo" is not non-null object
    
    Object.getOwnPropertyDescriptor("foo", 0);
    // { value: "f", writable: false, enumerable: true, configurable: false }