静态方法 Reflect
.defineProperty()
基本等同于 Object.defineProperty()
方法,唯一不同是返回 Boolean
值。
Reflect.defineProperty(target, propertyKey, attributes)
target
propertyKey
attributes
Boolean
值指示了属性是否被成功定义。
Reflect.defineProperty
方法允许精确添加或修改对象上的属性。更多的细节请参阅 Object.defineProperty
。Object.defineProperty
返回一个对象,或者如果属性没有被成功定义,抛出一个 TypeError
。 相比之下Reflect.defineProperty方法,
只是简单地返回一个 Boolean
说明该属性是否被成功定义。
Reflect.defineProperty()
const student = {};
Reflect.defineProperty(student, "name", {value: "Mike"}); // true
student.name; // "Mike"
Object.defineProperty
方法,如果成功则返回一个对象,否则抛出一个 TypeError
。另外,当定义一个属性时,你也可以使用 try...catch
块去捕获其中任何的错误。而因为 Reflect.defineProperty
返回 Boolean 值作为成功的状态,所以你也可以只使用 if...else
块:
if (Reflect.defineProperty(target, property, attributes)) {
// 成功
} else {
// 失败
}
Specification | Status | Comment |
---|---|---|
ECMAScript 2015 (6th Edition, ECMA-262) Reflect.defineProperty |
Standard | Initial definition. |
ECMAScript Latest Draft (ECMA-262) Reflect.defineProperty |
Draft |
Feature | Chrome | Edge | Firefox (Gecko) | Internet Explorer | Opera | Safari |
---|---|---|---|---|---|---|
Basic support | 49 | 12 | 42 (42) | 未实现 | 未实现 | 10 |
Feature | Android | Chrome for Android | Firefox Mobile (Gecko) | IE Mobile | Opera Mobile | Safari Mobile |
---|---|---|---|---|---|---|
Basic support | 未实现 | 49 | 42.0 (42) | 未实现 | 未实现 | 10 |