--- title: Reflect.defineProperty() slug: Web/JavaScript/Reference/Global_Objects/Reflect/defineProperty tags: - ECMAScript 2015 - JavaScript - Method - Reference - Reflect translation_of: Web/JavaScript/Reference/Global_Objects/Reflect/defineProperty ---
Reflect.defineProperty() 정적 메서드는 {{jsxref("Object.defineProperty()")}}와 같은 동작을 하지만 {{jsxref("Boolean")}}을 반환합니다.
Reflect.defineProperty(target, propertyKey, attributes)
targetpropertyKeyattributes속성이 성공적으로 정의됐는지 나타내는 {{jsxref("Boolean")}}.
target이 {{jsxref("Object")}}가 아니면 {{jsxref("TypeError")}}.
Reflect.defineProperty 메서드는 객체에 속성을 정교하게 추가하거나 수정할 수 있습니다. 자세한 내용은 유사한 메서드인 {{jsxref("Object.defineProperty")}}를 참고하세요. Object.defineProperty는 성공 시 대상 객체를 반환하고 실패하면 {{jsxref("TypeError")}}를 던지지만, Reflect.defineProperty는 성공 여부를 나타내는 {{jsxref("Boolean")}}을 반환합니다.
Reflect.defineProperty() 사용하기var obj = {};
Reflect.defineProperty(obj, 'x', {value: 7}); // true
obj.x; // 7
{{jsxref("Object.defineProperty")}}는 성공 시 객체를 반환하고, 실패 시 {{jsxref("TypeError")}}를 던지므로 속성 정의 과정에 발생할 수 있는 오류를 try...catch 블록으로 잡아야 합니다. 반면 Reflect.defineProperty는 성공 여부를 나타내는 {{jsxref("Boolean")}}을 반환하므로, 간단하게 if...else 블록만 사용하면 됩니다.
if (Reflect.defineProperty(target, property, attributes)) {
// 성공
} else {
// 실패
}
| Specification | Status | Comment |
|---|---|---|
| {{SpecName('ES2015', '#sec-reflect.defineproperty', 'Reflect.defineProperty')}} | {{Spec2('ES2015')}} | Initial definition. |
| {{SpecName('ESDraft', '#sec-reflect.defineproperty', 'Reflect.defineProperty')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.builtins.Reflect.defineProperty")}}