aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--files/ko/web/javascript/reference/global_objects/object/index.md401
1 files changed, 233 insertions, 168 deletions
diff --git a/files/ko/web/javascript/reference/global_objects/object/index.md b/files/ko/web/javascript/reference/global_objects/object/index.md
index d76739238f..4fd347fb92 100644
--- a/files/ko/web/javascript/reference/global_objects/object/index.md
+++ b/files/ko/web/javascript/reference/global_objects/object/index.md
@@ -2,176 +2,241 @@
title: Object
slug: Web/JavaScript/Reference/Global_Objects/Object
tags:
- - Constructor
+ - Class
- JavaScript
- Object
- - Reference
translation_of: Web/JavaScript/Reference/Global_Objects/Object
---
-<div>{{JSRef}}</div>
-<p><strong><code>Object</code></strong> 생성자는 객체 래퍼(wrapper)를 생성합니다.</p>
-
-<h2 id="구문">구문</h2>
-
-<pre class="syntaxbox">// 객체 초기자 또는 리터럴
-{ [ <var>nameValuePair1</var>[, <var>nameValuePair2</var>[, ...<var>nameValuePairN</var>] ] ] }
-
-// 생성자
-new Object([<var>value</var>])</pre>
-
-<h3 id="매개변수">매개변수</h3>
-
-<dl>
- <dt><code>nameValuePair1, nameValuePair2, ... nameValuePair<em>N</em></code></dt>
- <dd>콜론으로 나뉘어져 있는 키(문자열)와 값(어떤 값이나 가능)의 쌍.</dd>
- <dt><code>value</code></dt>
- <dd>아무 값.</dd>
-</dl>
-
-<h2 id="설명">설명</h2>
-
-<p><code>Object</code> 생성자는 주어진 값의 객체 래퍼를 생성합니다. 주어진 값이 {{jsxref("null")}}이거나 {{jsxref("undefined")}}면 빈 객체를 생성해 반환하고, 그렇지 않으면 값에 맞는 자료형의 객체를 반환합니다. 만약 값이 이미 객체이면 그 값을 그대로 반환합니다.</p>
-
-<p>생성자가 아닌 맥락에서 호출하면 <code>Object</code>는 <code>new Object()</code>와 동일하게 동작합니다.</p>
-
-<p><a href="/ko/docs/Web/JavaScript/Reference/Operators/Object_initializer">객체 초기자(리터럴 구문)</a>도 참고하세요.</p>
-
-<h2 id="Object_생성자의_속성"><code>Object</code> 생성자의 속성</h2>
-
-<dl>
- <dt><code>Object.length</code></dt>
- <dd>1의 값을 가집니다.</dd>
-</dl>
-
-<dl>
- <dt>{{jsxref("Object.prototype")}}</dt>
- <dd><code>Object</code> 형의 모든 객체에 속성을 추가할 수 있습니다.</dd>
-</dl>
-
-<h2 id="Object_생성자의_메서드"><code>Object</code> 생성자의 메서드</h2>
-
-<dl>
- <dt>{{jsxref("Object.assign()")}}</dt>
- <dd>하나 이상의 원본 객체들로부터 모든 열거가능한 속성들을 대상 객체로 복사합니다.</dd>
- <dt>{{jsxref("Object.create()")}}</dt>
- <dd>주어진 프로토타입(prototype)의 객체와 속성들을 갖고 있는 새 객체를 생성합니다.</dd>
- <dt>{{jsxref("Object.defineProperty()")}}</dt>
- <dd>주어진 기술자(descriptor)에 의해 기술된(described) 이름붙은 속성을 객체에 추가합니다.</dd>
- <dt>{{jsxref("Object.defineProperties()")}}</dt>
- <dd>주어진 기술자들에 맞는 이름붙은 속성들을 객체에 추가합니다.</dd>
- <dt>{{jsxref("Object.freeze()")}}</dt>
- <dd>객체를 프리징(freeze)합니다. 즉, 다른 곳의 코드에서 객체의 속성을 지우거나 바꿀 수 없습니다.</dd>
- <dt>{{jsxref("Object.getOwnPropertyDescriptor()")}}</dt>
- <dd>객체의 이름붙은 속성의 기술자를 반환합니다.</dd>
- <dt>{{jsxref("Object.getOwnPropertyNames()")}}</dt>
- <dd>주어진 객체 <strong>자신만의</strong> 열거가능하거나 열거불가능한 속성들의 이름을 포함하는 배열(array)을 반환합니다.</dd>
- <dt>{{jsxref("Object.getOwnPropertySymbols()")}}</dt>
- <dd>주어진 객체에서 바로 찾을 수 있는 모든 심볼 속성을 배열로 반환합니다.</dd>
- <dt>{{jsxref("Object.getPrototypeOf()")}}</dt>
- <dd>명시된 객체의 프로토타입을 반환.</dd>
- <dt>{{jsxref("Object.is()")}}</dt>
- <dd>두 값이 같은지를 비교합니다. 모든 NaN 값은 같다고 처리됩니다.(다른 추상적 또는 엄격한 등호 비교에서는 다르게 처리됩니다)</dd>
- <dt>{{jsxref("Object.isExtensible()")}}</dt>
- <dd>객체의 확장이 가능한지 확인합니다.</dd>
- <dt>{{jsxref("Object.isFrozen()")}}</dt>
- <dd>객체가 프리징 되었는지 확인합니다.</dd>
- <dt>{{jsxref("Object.isSealed()")}}</dt>
- <dd>객체가 실링(seal) 되었는지 확인합니다.</dd>
- <dt>{{jsxref("Object.keys()")}}</dt>
- <dd>주어진 객체 <strong>자신의 </strong>열거가능한 속성들의 이름의 배열을 반환합니다.</dd>
- <dt>{{jsxref("Object.preventExtensions()")}}</dt>
- <dd>객체가 확장되는 것을 못하도록 합니다.</dd>
- <dt>{{jsxref("Object.seal()")}}</dt>
- <dd>다른 코드가 객체의 속성을 삭제하지 못하도록 합니다.</dd>
- <dt>{{jsxref("Object.setPrototypeOf()")}}</dt>
- <dd>프로토타입(즉, 내부의 <code>[[Prototype]]</code> 속성)을 설정합니다.</dd>
-</dl>
-
-<dl>
- <dt>{{jsxref("Object.values()")}}</dt>
- <dd>주어진 객체의 열거가능한 모든 스트링 속성들의 값들을 포함하고 있는 배열을 반환합니다.</dd>
-</dl>
-
-<h2 id="Object_instances"><code>Object</code> 인스턴스와 <code>Object</code> 프로토타입 객체</h2>
-
-<p>JavaScript에서 모든 객체들은 <code>Object</code>의 자손입니다. 모든 객체는 {{jsxref("Object.prototype")}}으로부터 메서드와 속성을 상속하는데, 나중에 덮어 쓸 수도 있습니다. 예를 들어, 다른 생성자의 프로토타입은 그 <code>constructor</code> 속성을 덮어쓰고 자신의 <code>toString()</code> 메소드들을 제공합니다. <code>Object</code> 프로토타입 객체에 대한 변경 내용은  그 변경 내용에 영향을 받는 속성들과 메소드들이 프로토타입 체인(chain)을 따라 더이상 무시되지 않는한,  모든 객체들로 전달됩니다.</p>
-
-<h3 id="속성">속성</h3>
-
-<div>{{page('/ko/docs/Web/JavaScript/Reference/Global_Objects/Object/prototype', '속성') }}</div>
-
-<h3 id="메서드">메서드</h3>
-
-<div>{{page('/ko/docs/Web/JavaScript/Reference/Global_Objects/Object/prototype', '메서드') }}</div>
-
-<h2 id="Examples">예제</h2>
-
-<h3 id="Example.3A_Using_Object_given_undefined_and_null_types"><code>undefined</code>와 <code>null</code>을 지정</h3>
-
-<p>다음 예제는 변수 <code>o</code>에 빈 <code>Object</code> 객체를 저장합니다.</p>
-
-<pre class="brush: js">var o = new Object();
-</pre>
-
-<pre class="brush: js">var o = new Object(undefined);
-</pre>
-
-<pre class="brush: js">var o = new Object(null);
-</pre>
-
-<h3 id="Object로_Boolean_객체_생성하기"><code>Object</code>로 <code>Boolean</code> 객체 생성하기</h3>
-
-<p>다음 예제는 변수 <code>o</code>에 {{jsxref("Boolean")}} 객체를 저장합니다.</p>
-
-<pre class="brush: js">// o = new Boolean(true)과 같음
-var o = new Object(true);
-</pre>
-
-<pre class="brush: js">// o = new Boolean(false)과 같음
-var o = new Object(Boolean());
-</pre>
-
-<h2 id="명세">명세</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>ECMAScript 1st Edition.</td>
- <td>Standard</td>
- <td>Initial definition. Implemented in JavaScript 1.0.</td>
- </tr>
- <tr>
- <td>{{SpecName('ES5.1', '#sec-15.2', 'Object')}}</td>
- <td>{{Spec2('ES5.1')}}</td>
- <td> </td>
- </tr>
- <tr>
- <td>{{SpecName('ES6', '#sec-object-objects', 'Object')}}</td>
- <td>{{Spec2('ES6')}}</td>
- <td>Added Object.assign, Object.getOwnPropertySymbols, Object.setPrototypeOf, Object.is</td>
- </tr>
- <tr>
- <td>{{SpecName('ESDraft', '#sec-object-objects', 'Object')}}</td>
- <td>{{Spec2('ESDraft')}}</td>
- <td>Added Object.entries, Object.values and Object.getOwnPropertyDescriptors.</td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="브라우저_호환성">브라우저 호환성</h2>
-
-
-
-<p>{{Compat("javascript.builtins.Object")}}</p>
-
-<h2 id="See_also">같이 보기</h2>
-
-<ul>
- <li><a href="https://developer.mozilla.org/ko/docs/Web/JavaScript/Reference/Operators/Object_initializer">Object initializer</a></li>
-</ul>
+{{JSRef}}
+
+**`Object`** 클래스는 [JavaScript의 데이터 유형](/ko/docs/Web/JavaScript/Data_structures) 중 하나를 나타냅니다. 다양한 키 모음 및 더 복잡한 엔티티들을 저장하는 데 사용됩니다. 객체는 {{jsxref("Object/Object", "Object()")}} 생성자 또는 [객체 초기자 / 리터럴 구문](/ko/docs/Web/JavaScript/Reference/Operators/Object_initializer)를 통해 생성할 수 있습니다.
+
+## 설명
+
+JavaScript의 거의 모든 객체는 {{jsxref("Object")}}의 인스턴스입니다. 일반적인 객체는 `Object.prototype`에서 속성(메서드 포함)을 상속하지만, 이러한 속성들은 가려질(재정의될) 수 있습니다. 그러나 `Object`는 의도적으로 가려지지 않게 생성되거나(예: {{jsxref("Object.create", "Object.create(null)")}}), 더이상 가려지지 않도록 변경될 수 있습니다(예: {{jsxref("Object.setPrototypeOf")}}).
+
+`Object` 프로토타입 객체에 대한 변경 사항은 해당 변경 사항의 대상이 되는 프로토타입 체인상의 속성 및 메서드가 추가로 재정의되지 않는 한 프로토타입 체인을 통해 **모든** 객체에서 볼 수 있습니다. 이것은 객체 동작을 재정의하거나 확장하는 매우 강력하지만 잠재적으로 위험한 메커니즘을 제공합니다.
+
+`Object` 생성자는 주어진 값에 대한 객체 래퍼를 생성합니다.
+
+- 값이 {{jsxref("null")}} 또는 {{jsxref("undefined")}}이면 빈 객체를 생성하여 반환합니다.
+- 그렇지 않으면 주어진 값에 해당하는 타입의 객체를 반환합니다.
+- 값이 이미 객체인 경우 그 값을 반환합니다.
+
+생성자가 아닌 맥락에서 호출될 때 `Object`는 `new Object()`와 동일하게 작동합니다.
+
+[객체 초기자 / 리터럴 구문](/ko/docs/Web/JavaScript/Reference/Operators/Object_initializer)도 참조하세요.
+
+### 객체의 속성 삭제하기
+
+객체 자체에는 속성을 삭제하는 메서드가 없습니다(예: {{jsxref("Map.prototype.delete", "Map.prototype.delete()")}}). 삭제하기 위해서는 [delete 연산자](/ko/docs/Web/JavaScript/Reference/Operators/delete)를 사용해야 합니다.
+
+## 생성자
+
+- {{jsxref("Object/Object", "Object()")}}
+ - : 새 `Object` 객체를 만듭니다. 이 때 생성된 객체는 주어진 값에 대한 래퍼입니다.
+
+## 정적 메서드
+
+- {{jsxref("Object.assign","Object.assign()")}}
+ - : 하나 이상의 원본 객체들로부터 모든 열거 가능한 속성들을 대상 객체로 복사합니다.
+- {{jsxref("Object.create","Object.create()")}}
+ - : 지정한 프로토타입(prototype)의 객체 및 속성을 갖고 있는 새 객체를 생성합니다.
+- {{jsxref("Object.defineProperty","Object.defineProperty()")}}
+ - : 지정한 서술자(descriptor)에서 서술한 속성을 객체에 추가합니다.
+- {{jsxref("Object.defineProperties","Object.defineProperties()")}}
+ - : 지정한 서술자들에서 서술한 속성들을 객체에 추가합니다.
+- {{jsxref("Object.entries","Object.entries()")}}
+ - : 지정한 객체 **자신의** 모든 열거 가능한 문자열 속성들의 `[key, value]` 쌍으로 구성된 배열을 반환합니다.
+- {{jsxref("Object.freeze","Object.freeze()")}}
+ - : 객체를 고정(freeze)합니다. 다른 곳의 코드에서 해당 속성을 삭제하거나 변경할 수 없게 됩니다.
+- {{jsxref("Object.fromEntries","Object.fromEntries()")}}
+ - : `[key, value]` 쌍의 iterable로부터 새 객체를 반환합니다. ({{jsxref("Object.entries")}}의 반대입니다.)
+- {{jsxref("Object.getOwnPropertyDescriptor","Object.getOwnPropertyDescriptor()")}}
+ - : 객체의 지정한 속성에 대한 속성 서술자를 반환합니다.
+- {{jsxref("Object.getOwnPropertyDescriptors","Object.getOwnPropertyDescriptors()")}}
+ - : 객체 자신의 모든 속성 서술자들로 구성된 객체를 반환합니다.
+- {{jsxref("Object.getOwnPropertyNames","Object.getOwnPropertyNames()")}}
+ - : 지정한 객체 **자신의** 모든 열거 가능하거나 불가능한 속성들의 이름으로 구성된 배열을 반환합니다.
+- {{jsxref("Object.getOwnPropertySymbols","Object.getOwnPropertySymbols()")}}
+ - : 지정한 객체 자신의 모든 심볼 속성들로 구성된 배열을 반환합니다.
+- {{jsxref("Object.getPrototypeOf","Object.getPrototypeOf()")}}
+ - : 지정한 객체의 프로토타입(내부 `[[Prototype]]` 속성)을 반환합니다.
+- {{jsxref("Object.is","Object.is()")}}
+ - : 두 값이 같은지를 비교합니다. 모든 `NaN` 값을 같다고 처리합니다. (추상 동등 비교 및 ​​엄격한 동등 비교와 다른 점입니다.)
+- {{jsxref("Object.isExtensible","Object.isExtensible()")}}
+ - : 객체의 확장이 가능한지 여부를 확인합니다.
+- {{jsxref("Object.isFrozen","Object.isFrozen()")}}
+ - : 객체가 고정(freeze)되었는지 여부를 확인합니다.
+- {{jsxref("Object.isSealed","Object.isSealed()")}}
+ - : 객체가 봉인(seal)되었는지 여부를 확인합니다.
+- {{jsxref("Object.keys","Object.keys()")}}
+ - : 지정한 객체 **자신의** 모든 열거 가능한 문자열 속성들의 이름으로 구성된 배열을 반환합니다.
+- {{jsxref("Object.preventExtensions","Object.preventExtensions()")}}
+ - : 객체가 확장되지 못하도록 합니다.
+- {{jsxref("Object.seal","Object.seal()")}}
+ - : 다른 코드가 객체의 속성을 삭제하지 못하도록 합니다.
+- {{jsxref("Object.setPrototypeOf","Object.setPrototypeOf()")}}
+ - : 객체의 프로토타입(내부 `[[Prototype]]` 속성)을 설정합니다.
+- {{jsxref("Object.values","Object.values()")}}
+ - : 지정한 객체 **자신의** 모든 열거 가능한 문자열 속성에 해당하는 값들로 구성된 배열을 반환합니다.
+
+## 인스턴스 속성
+
+- {{jsxref("Object.prototype.constructor")}}
+ - : 객체의 프로토타입을 생성하는 함수를 지정합니다.
+- {{jsxref("Object/proto","Object.prototype.__proto__")}}
+ - : 객체가 인스턴스화될 때 프로토타입으로 사용된 객체를 가리킵니다.
+
+## 인스턴스 메서드
+
+- {{jsxref("Object.prototype.__defineGetter__()")}}
+ - : 액세스(get)할 때 실행되어 값을 반환하는 함수와 지정한 속성을 연결합니다.
+- {{jsxref("Object.prototype.__defineSetter__()")}}
+ - : 설정(set)할 때 실행되어 해당 속성을 수정하는 함수와 지정한 속성을 연결합니다.
+- {{jsxref("Object.prototype.__lookupGetter__()")}}
+ - : {{jsxref("Object.prototype.__defineGetter__()", "__defineGetter__()")}} 메서드에 의해 지정된 속성과 연결된 함수를 반환합니다.
+- {{jsxref("Object.prototype.__lookupSetter__()")}}
+ - : {{jsxref("Object.prototype.__defineSetter__()", "__defineSetter__()")}} 메서드에 의해 지정된 속성과 연결된 함수를 반환합니다.
+- {{jsxref("Object.prototype.hasOwnProperty()")}}
+ - : 객체에 지정한 속성이 해당 객체에 직접 포함되어 있고 프로토타입 체인을 통해 상속되지 않는지 여부를 나타내는 불리언 값을 반환합니다.
+- {{jsxref("Object.prototype.isPrototypeOf()")}}
+ - : 이 메서드를 호출한 객체가 지정한 객체의 프로토타입 체인에 있는지 여부를 나타내는 불리언 값을 반환합니다.
+- {{jsxref("Object.prototype.propertyIsEnumerable()")}}
+ - : 내부 [ECMAScript \[\[Enumerable\]\] 속성](/ko/docs/Web/JavaScript/Data_structures##%ec%86%8d%ec%84%b1_properties)이 설정되었는지 여부를 나타내는 불리언 값을 반환합니다.
+- {{jsxref("Object.prototype.toLocaleString()")}}
+ - : {{jsxref("Object.toString", "toString()")}}를 호출합니다.
+- {{jsxref("Object.prototype.toString()")}}
+ - : 객체의 문자열 표현을 반환합니다.
+- {{jsxref("Object.prototype.valueOf()")}}
+ - : 지정한 객체의 원시 값을 반환합니다.
+
+## 예제
+
+### `undefined` 및 `null` 타입을 지정한 `Object` 사용
+
+다음 예제는 변수 `o`에 빈 `Object` 객체를 저장합니다.
+
+```js
+let o = new Object()
+```
+
+```js
+let o = new Object(undefined)
+```
+
+```js
+let o = new Object(null)
+```
+
+### `Object`로 `Boolean` 객체 생성하기
+
+다음 예제는 변수 `o`에 {{jsxref("Boolean")}} 객체를 저장합니다.
+
+```js
+// o = new Boolean(true) 와 같음
+let o = new Object(true)
+```
+
+```js
+// o = new Boolean(false) 와 같음
+let o = new Object(Boolean())
+```
+
+### 객체 프로토타입
+
+기존 `Object.prototype` 메서드의 동작을 변경하고자 할 때에는 기존 내용의 앞이나 뒤에 확장할 내용을 래핑하여 코드를 주입하는 것을 고려하세요. 예를 들어, 이 (테스트되지 않은) 코드는 기본 제공 코드 또는 다른 사람의 확장 실행되기 전에 사전 조건부로 사용자 정의 코드를 실행합니다.
+
+함수가 호출되면 호출에 대한 매개변수가 유사배열 "변수" [arguments 객체](/ko/docs/Web/JavaScript/Reference/Functions/arguments)에 보관됩니다. 예를 들어, `myFn(a, b, c)`를 호출하면 `myFn` 본문 내의 arguments 객체에는 `(a, b, c)`에 해당하는 3개의 유사배열요소가 포함됩니다.
+
+hook을 통해 프로토타입을 수정하고자 할 때엔 해당 함수에서 `apply()`를 호출하면서 `this`와 arguments 객체를 현재 동작에 전달합니다. 이 패턴은 `Node.prototype`, `Function.prototype` 등 모든 프로토타입에 적용할 수 있습니다.
+
+```js
+var current = Object.prototype.valueOf
+// 내가 지정한 속성 "-prop-value"은 범분야에 걸쳐 사용되고 있고
+// 항상 동일한 프로토타입 체인에 있지 않기 때문에,
+// Object.prototype을 수정하고 싶습니다.
+Object.prototype.valueOf = function () {
+ if (this.hasOwnProperty('-prop-value')) {
+ return this['-prop-value']
+ } else {
+ // 내가 만든 객체가 아닌 것 같으므로,
+ // 가능한 최선을 다해 원래의 동작을 재현하여 기본 동작으로 돌아가겠습니다.
+ // 'apply' 메서드는 다른 언어에서의 'super'처럼 작동합니다.
+ // valueOf()가 arguments를 취하지 않더라도, 다른 hook이 있으리라 생각합니다.
+ return current.apply(this, arguments)
+ }
+}
+```
+
+JavaScript에는 명확한 하위 클래스 객체가 없기 때문에, 프로토타입은 특정 기능의 "기본 클래스" 객체를 만드는 데 유용한 해결 방법입니다. 예를 들어:
+
+```js
+var Person = function (name) {
+ this.name = name
+ this.canTalk = true
+}
+Person.prototype.greet = function () {
+ if (this.canTalk) {
+ console.log('Hi, I am ' + this.name)
+ }
+}
+var Employee = function (name, title) {
+ Person.call(this, name)
+ this.title = title
+}
+Employee.prototype = Object.create(Person.prototype)
+Employee.prototype.constructor = Employee
+// Object.prototype.constructor를 Employee로 설정하지 않으면
+// Person (parent)의 prototype.constructor를 사용합니다.
+// 이를 피하기 위해 prototype.constructor를 Employee (child)로 설정합니다.
+Employee.prototype.greet = function () {
+ if (this.canTalk) {
+ console.log('Hi, I am ' + this.name + ', the ' + this.title)
+ }
+}
+var Customer = function (name) {
+ Person.call(this, name)
+}
+Customer.prototype = Object.create(Person.prototype)
+Customer.prototype.constructor = Customer
+// Object.prototype.constructor를 Customer로 설정하지 않으면
+// Person (parent)의 prototype.constructor를 사용합니다.
+// 이를 피하기 위해 prototype.constructor를 Customer (child)로 설정합니다.
+var Mime = function (name) {
+ Person.call(this, name)
+ this.canTalk = false
+}
+Mime.prototype = Object.create(Person.prototype)
+Mime.prototype.constructor = Mime
+// Object.prototype.constructor를 Mime로 설정하지 않으면
+// Person (parent)의 prototype.constructor를 사용합니다.
+// 이를 피하기 위해 prototype.constructor를 Mime (child)로 설정합니다.
+var bob = new Employee('Bob', 'Builder')
+var joe = new Customer('Joe')
+var rg = new Employee('Red Green', 'Handyman')
+var mike = new Customer('Mike')
+var mime = new Mime('Mime')
+bob.greet()
+// Hi, I am Bob, the Builder
+joe.greet()
+// Hi, I am Joe
+rg.greet()
+// Hi, I am Red Green, the Handyman
+mike.greet()
+// Hi, I am Mike
+mime.greet()
+```
+
+## 명세
+
+{{Specifications}}
+
+## 브라우저 호환성
+
+{{Compat}}
+
+## 같이 보기
+
+- [객체 초기자](/ko/docs/Web/JavaScript/Reference/Operators/Object_initializer)