--- 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)
target
propertyKey
attributes
속성이 성공적으로 정의됐는지 나타내는 {{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")}}