aboutsummaryrefslogtreecommitdiff
path: root/files/ko/web
diff options
context:
space:
mode:
Diffstat (limited to 'files/ko/web')
-rw-r--r--files/ko/web/javascript/reference/global_objects/object/assign/index.md227
1 files changed, 98 insertions, 129 deletions
diff --git a/files/ko/web/javascript/reference/global_objects/object/assign/index.md b/files/ko/web/javascript/reference/global_objects/object/assign/index.md
index 31d545dd4f..c691b8f326 100644
--- a/files/ko/web/javascript/reference/global_objects/object/assign/index.md
+++ b/files/ko/web/javascript/reference/global_objects/object/assign/index.md
@@ -7,105 +7,65 @@ tags:
- Method
- Object
- Reference
- - polyfill
- - 객체
- - 레퍼런스
- - 메소드
+ - Polyfill
browser-compat: javascript.builtins.Object.assign
translation_of: Web/JavaScript/Reference/Global_Objects/Object/assign
---
-<div>{{JSRef}}</div>
+{{JSRef}}
-<p><strong><code>Object.assign()</code> </strong>메소드는 출처 객체로부터 모든 열거할 수 있는({{jsxref("Object/propertyIsEnumerable", "enumerable", "", 1)}}) 하나 이상의 속성({{jsxref("Object/hasOwnProperty", "own properties", "", 1)}})들을 목표 객체로 복사합니다. 이는 수정된 목표 객체를 반환합니다.</p>
+**`Object.assign()`** 메서드는 출처 객체들의 모든 {{jsxref("Object/propertyIsEnumerable", "열거 가능", "", 1)}}한 {{jsxref("Object/hasOwnProperty", "자체 속성", "", 1)}}을 복사해 대상 객체에 붙여넣습니다. 그 후 대상 객체를 반환합니다.
-<p>{{EmbedInteractiveExample("pages/js/object-assign.html")}}</p>
+{{EmbedInteractiveExample("pages/js/object-assign.html")}}
-<h2 id="Syntax">구문</h2>
+## 구문
-<pre class="syntaxbox">Object.assign(<var>target</var>, ...<var>sources</var>)</pre>
+```js
+Object.assign(target, ...sources)
+```
-<h3 id="Parameters">매개변수</h3>
+### 매개변수
-<dl>
- <dt><code><var>target</var></code></dt>
- <dd>목표 객체 - 출처 객체의 속성을 받아 반영된 목표 객체를 반환합니다.</dd>
- <dt><code><var>sources</var></code></dt>
- <dd>출처 객체(들) - 목표 객체에 반영하고자 하는 속성들을 갖고 있는 객체입니다.</dd>
-</dl>
+- `target`
+ - : 목표 객체. 출처 객체의 속성을 복사해 반영한 후 반환할 객체입니다.
+- `sources`
+ - : 출처 객체. 목표 객체에 반영하고자 하는 속성들을 갖고 있는 객체들입니다.
-<h3 id="Return_value">반환 값</h3>
+### 반환 값
-<p>목표 객체</p>
+목표 객체.
-<h2 id="Description">설명</h2>
+## 설명
-<p>목표 객체에 동일한 {{jsxref("Object/keys", "키", "", 1)}}를 갖는 속성이 존재할 경우 그 속성 값은 출처 객체의 속성 값으로 덮어쓰여집니다. 동일하게, 앞의 출처 속성들은 뒤의 출처 속성들에게 덮어쓰여집니다.</p>
+목표 객체의 속성 중 출처 객체와 동일한 {{jsxref("Object/keys", "키", "", 1)}}를 갖는 속성의 경우, 그 속성 값은 출처 객체의 속성 값으로 덮어씁니다. 출처 객체들의 속성 중에서도 키가 겹칠 경우 뒤쪽 객체의 속성 값이 앞쪽 객체의 속성 값보다 우선합니다.
-<p><code>Object.assign()</code> 메소드는 출처 객체의 열거할 수 있는 속성만 목표 객체로 복사합니다. 이 메소드는 출처 객체의 <code>[[Get]]</code>, 목표 객체의 <code>[[Set]]</code> 을 사용하여 getter 와 setter 를 호출합니다. 그러므로 이는 속성을 단순히 복사하거나 새롭게 정의하는 것이 아니라 할당하는 것입니다.
- 병합될 출처 객체들이 getter 를 포함하는 경우 프로토타입에 새로운 속성들을 병합하기에는 적절하지 않을 수 있습니다.
-</p>
+`Object.assign()` 메서드는 출처 객체의 '열거 가능한 자체 속성'만 목표 객체로 복사합니다. 출처 객체에서 속성 값을 가져올 땐 `[[Get]]`, 목표 객체에 속성 값을 지정할 땐 `[[Set]]`을 사용하므로 각각 [접근자](/ko/docs/Web/JavaScript/Reference/Functions/get)와 [설정자](/ko/docs/Web/JavaScript/Reference/Functions/set)를 호출합니다. 그러므로 `Object.assign()`은 속성을 단순히 복사하거나 새로 정의하는 것이 아니라, 할당(_assign_)하는 것입니다. 따라서 출처 객체가 접근자를 포함하는 경우, 프로토타입에 새로운 속성을 추가하는 용도로는 적합하지 않을 수도 있습니다.
-<p>속성의 열거성을 포함한 속성의 정의를 프로토타입으로 복사하려면 대신 {{jsxref("Object.getOwnPropertyDescriptor()")}} 와 {{jsxref("Object.defineProperty()")}} 를 사용해야합니다.</p>
+열거성을 포함한 속성 정의를 프로토타입으로 복사하려면 {{jsxref("Object.getOwnPropertyDescriptor()")}}와 {{jsxref("Object.defineProperty()")}}를 사용하세요.
-<p>{{jsxref("String")}} 과 {{jsxref("Symbol")}} 속성 모두가 복사됩니다.</p>
+`Object.assign()`은 {{jsxref("String")}} 키와 {{jsxref("Symbol")}} 키 속성 모두 복사합니다.
-<p>에러가 발생할 수 있는 상황에서는(예, 프로퍼티가 쓰기 불가인 경우), {{jsxref("TypeError")}} 가 발생하며, 에러가 발생하기 전에 속성이 추가되었다면 <code>목표</code> 객체는 변경될 수 있습니다.</p>
+오류(대상 객체의 속성이 쓰기 불가한 상태 등)를 마주치면 {{jsxref("TypeError")}}가 발생합니다. 그러나 오류가 발생하기 전에 이미 추가/변경한 다른 속성의 값은 대상 객체에 유지됩니다.
-<div class="notecard note">
- <p><strong>Note:</strong> <code>Object.assign()</code> 메소드는
- {{jsxref("null")}} 또는 {{jsxref("undefined")}} 출처 값에 대해서 예외를 던지지 않음을 유의하세요.</p>
-</div>
+> **참고:** `Object.assign()`의 출처에 {{jsxref("null")}} 또는 {{jsxref("undefined")}}를 제공해도 예외는 발생하지 않습니다.
-<h2 id="Polyfill">폴리필</h2>
+## 예제
-<p>ES5 에는 심볼이 없기 때문에 다음 {{Glossary("Polyfill","폴리필")}} 은 심볼 속성을 지원하지 않습니다.</p>
+### 객체 복제
-<pre class="brush: js">if (typeof Object.assign != 'function') {
- // Must be writable: true, enumerable: false, configurable: true
- Object.defineProperty(Object, "assign", {
- value: function assign(target, varArgs) { // .length of function is 2
- 'use strict';
- if (target == null) { // TypeError if undefined or null
- throw new TypeError('Cannot convert undefined or null to object');
- }
-
- var to = Object(target);
-
- for (var index = 1; index &lt; arguments.length; index++) {
- var nextSource = arguments[index];
-
- if (nextSource != null) { // Skip over if undefined or null
- for (var nextKey in nextSource) {
- // Avoid bugs when hasOwnProperty is shadowed
- if (Object.prototype.hasOwnProperty.call(nextSource, nextKey)) {
- to[nextKey] = nextSource[nextKey];
- }
- }
- }
- }
- return to;
- },
- writable: true,
- configurable: true
- });
-}</pre>
-
-<h2 id="Examples">예시</h2>
-
-<h3 id="Cloning_an_object">객체 복제</h3>
-
-<pre class="brush: js">const obj = { a: 1 };
+```js
+const obj = { a: 1 };
const copy = Object.assign({}, obj);
console.log(copy); // { a: 1 }
-</pre>
+```
-<h3 id="Deep_Clone">깊은 복사에 대한 주의사항</h3>
+### 깊은 복사 주의점
-<p>깊은 복사를 위해서는, 다른 방법을 사용해야 합니다. 왜냐하면 <code>Object.assign()</code> 은 속성 값을 복사하기 때문입니다.</p>
+`Object.assign()`은 속성의 값을 복사하기 때문에, 깊은 복사를 수행하려면 다른 방법을 사용해야 합니다.
-<p>만약 출처 값이 객체를 참조하고 있다면, 참조 값만 복사합니다.</p>
+만약 출처 값이 객체에 대한 참조라면 참조 값만 복사합니다.
-<pre class="brush: js">function test() {
+```js
+function test() {
'use strict';
let obj1 = { a: 0 , b: { c: 0}};
@@ -120,7 +80,7 @@ console.log(copy); // { a: 1 }
console.log(JSON.stringify(obj1)); // { a: 1, b: { c: 0}}
console.log(JSON.stringify(obj2)); // { a: 2, b: { c: 0}}
- obj2.b.c = 3; // obj1, obj2 모두에 영향을 줌
+ obj2.b.c = 3;
console.log(JSON.stringify(obj1)); // { a: 1, b: { c: 3}}
console.log(JSON.stringify(obj2)); // { a: 2, b: { c: 3}}
@@ -132,108 +92,119 @@ console.log(copy); // { a: 1 }
console.log(JSON.stringify(obj3)); // { a: 0, b: { c: 0}}
}
-test();</pre>
+test();
+```
-<h3 id="Merging_objects">객체 병합</h3>
+### 객체 병합
-<pre class="brush: js">const o1 = { a: 1 };
+```js
+const o1 = { a: 1 };
const o2 = { b: 2 };
const o3 = { c: 3 };
const obj = Object.assign(o1, o2, o3);
console.log(obj); // { a: 1, b: 2, c: 3 }
-console.log(o1); // { a: 1, b: 2, c: 3 }, 목표 객체 자체가 변경됨.</pre>
+console.log(o1); // { a: 1, b: 2, c: 3 }, 목표 객체 자체가 변경됨.
+```
-<h3 id="Merging_objects_with_same_properties">같은 속성을 가진 객체 병합</h3>
+### 같은 속성을 가진 객체 병합
-<pre class="brush: js">const o1 = { a: 1, b: 1, c: 1 };
+```js
+const o1 = { a: 1, b: 1, c: 1 };
const o2 = { b: 2, c: 2 };
const o3 = { c: 3 };
const obj = Object.assign({}, o1, o2, o3);
-console.log(obj); // { a: 1, b: 2, c: 3 }</pre>
+console.log(obj); // { a: 1, b: 2, c: 3 }
+```
-<p>속성들은 매개변수 순서에서 더 뒤에 위치하고 동일한 속성을 가진 다른 객체에 의해 덮어쓰여집니다.</p>
+같은 키를 가진 속성의 경우 매개변수 순서에서 더 뒤에 위치한 객체의 값으로 덮어씁니다.
-<h3 id="Copying_symbol-typed_properties">심볼형 속성 복사</h3>
+### 심볼 속성 복사
-<pre class="brush: js">const o1 = { a: 1 };
+```js
+const o1 = { a: 1 };
const o2 = { [Symbol('foo')]: 2 };
const obj = Object.assign({}, o1, o2);
console.log(obj); // { a : 1, [Symbol("foo")]: 2 } (cf. bug 1207182 on Firefox)
Object.getOwnPropertySymbols(obj); // [Symbol(foo)]
-</pre>
+```
-<h3 id="Properties_on_the_prototype_chain_and_non-enumerable_properties_cannot_be_copied">프로토타입 체인의 속성과 열거 할 수 없는 속성은 복사 불가</h3>
+### 프로토타입 체인의 속성과 열거 불가능한 속성은 복사 불가
-<pre class="brush: js">const obj = Object.create({ foo: 1 }, { // foo 는 obj 의 프로토타입 체인에 있음.
+```js
+const obj = Object.create({ foo: 1 }, { // foo는 obj의 프로토타입 체인에 있음
bar: {
- value: 2 // bar 는 열거할 수 없는 속성.
+ value: 2 // bar는 열거 불가능
},
baz: {
value: 3,
- enumerable: true // baz 는 열거형 속성임.
+ enumerable: true // baz는 열거 가능한 자체 속성
}
});
const copy = Object.assign({}, obj);
console.log(copy); // { baz: 3 }
-</pre>
+```
-<h3 id="Primitives_will_be_wrapped_to_objects">원시 자료형은 객체로 래핑</h3>
+### 원시 값은 객체로 래핑
-<pre class="brush: js">var v1 = 'abc';
-var v2 = true;
-var v3 = 10;
-var v4 = Symbol('foo');
+```js
+const v1 = 'abc';
+const v2 = true;
+const v3 = 10;
+const v4 = Symbol('foo');
-var obj = Object.assign({}, v1, null, v2, undefined, v3, v4);
-// 원시 자료형은 래핑되지만, null 과 undefined 는 무시.
-// 문자열 래퍼만 자체 열거형 속성을 가짐을 유의.
+const obj = Object.assign({}, v1, null, v2, undefined, v3, v4);
+// 원시 값은 래핑하고, null과 undefined는 무시
+// 참고: 문자열 래퍼만 자체 열거형 속성을 가질 수 있음
console.log(obj); // { "0": "a", "1": "b", "2": "c" }
-</pre>
+```
-<h3 id="Exceptions_will_interrupt_the_ongoing_copying_task">예외에 의해 진행중인 복사 작업 중단</h3>
+### 예외로 인한 복사 작업 중단
-<pre class="brush: js">var target = Object.defineProperty({}, 'foo', {
+```js
+const target = Object.defineProperty({}, 'foo', {
value: 1,
writable: false
-}); // target.foo 는 읽기 전용 속성
+}); // target.foo는 읽기 전용 속성
Object.assign(target, { bar: 2 }, { foo2: 3, foo: 3, foo3: 3 }, { baz: 4 });
// TypeError: "foo" is read-only
-// target.foo 에 할당할 때 예외 발생
+// target.foo에 할당할 때 예외 발생
-console.log(target.bar); // 2, 첫 번째 출처 객체는 성공적으로 복사되었음.
-console.log(target.foo2); // 3, 두 번째 출처 객체의 첫 번째 프로퍼티도 성공적으로 복사되었음.
-console.log(target.foo); // 1, 여기에서 예외가 발생.
-console.log(target.foo3); // undefined, assign 메소드가 종료되었음, foo3 은 복사되지 않음.
-console.log(target.baz); // undefined, 세 번째 출처 객체도 복사되지 않음.
-</pre>
+console.log(target.bar); // 2, 첫 번째 출처 객체는 성공적으로 복사함
+console.log(target.foo2); // 3, 두 번째 출처 객체 중 첫 번째 속성도 성공적으로 복사함
+console.log(target.foo); // 1, 여기에서 예외가 발생했음
+console.log(target.foo3); // undefined, assign 메서드가 종료됨, foo3은 복사되지 않음
+console.log(target.baz); // undefined, 세 번째 출처 객체도 복사되지 않음
+```
-<h3 id="Copying_accessors">접근자 복사</h3>
+### 접근자 복사
-<pre class="brush: js">var obj = {
+```js
+const obj = {
foo: 1,
get bar() {
return 2;
}
};
-var copy = Object.assign({}, obj);
+let copy = Object.assign({}, obj);
console.log(copy);
-// { foo: 1, bar: 2 }, copy.bar 의 값은 obj.bar 의 getter 의 반환 값임.
+// { foo: 1, bar: 2 }, copy.bar의 값은 obj.bar의 접근자가 반환한 값
-// 모든 descriptors 를 복사하는 할당 함수
+// 속성의 온전한 기술자를 복사해 할당하는 함수
function completeAssign(target, ...sources) {
- sources.forEach(source =&gt; {
-  let descriptors = Object.keys(source).reduce((descriptors, key) =&gt; {
+ sources.forEach(source => {
+  let descriptors = Object.keys(source).reduce((descriptors, key) => {
  descriptors[key] = Object.getOwnPropertyDescriptor(source, key);
  return descriptors;
  }, {});
-  // 기본적으로, Object.assign 는 열거형 Symbol 도 복사함.
-  Object.getOwnPropertySymbols(source).forEach(sym =&gt; {
+
+  // 기본적으로 Object.assign은 열거 가능한 심볼도 복사함
+  Object.getOwnPropertySymbols(source).forEach(sym => {
  let descriptor = Object.getOwnPropertyDescriptor(source, sym);
  if (descriptor.enumerable) {
  descriptors[sym] = descriptor;
@@ -244,24 +215,22 @@ function completeAssign(target, ...sources) {
return target;
}
-var copy = completeAssign({}, obj);
+copy = completeAssign({}, obj);
console.log(copy);
// { foo:1, get bar() { return 2 } }
-</pre>
+```
-<h2 id="Specifications">명세</h2>
+## 명세
{{Specifications}}
-<h2 id="브라우저_호환성">브라우저 호환성</h2>
+## 브라우저 호환성
-<p>{{Compat}}</p>
+{{Compat}}
-<h2 id="See_also">같이 보기</h2>
+## 같이 보기
-<ul>
- <li><code>Object.assign</code> 의 폴리필은 다음에서 확인할 수 있습니다. <a href="https://github.com/zloirock/core-js#ecmascript-object"><code>core-js</code></a></li>
- <li>{{jsxref("Object.defineProperties()")}}</li>
- <li><a href="/ko/docs/Web/JavaScript/Enumerability_and_ownership_of_properties">속성의 열거성과 소유권</a></li>
- <li><a href="/ko/docs/Web/JavaScript/Reference/Operators/Spread_syntax#spread_in_object_literals">객체 리터럴에서의 Spread</a></li>
-</ul>
+- [`core-js`의 `Object.assign` 폴리필](https://github.com/zloirock/core-js#ecmascript-object)
+- {{jsxref("Object.defineProperties()")}}
+- [속성의 소유권과 열거 가능성](/ko/docs/Web/JavaScript/Enumerability_and_ownership_of_properties)
+- [객체 리터럴에서의 전개 구문](/ko/docs/Web/JavaScript/Reference/Operators/Spread_syntax#spread_in_object_literals)