静态方法 Reflect.defineProperty() 基本等同于 Object.defineProperty() 方法,唯一不同是返回 Boolean 值。
Reflect.defineProperty(target, propertyKey, attributes)
targetpropertyKeyattributes 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 |