diff options
author | alattalatta <urty5656@gmail.com> | 2021-09-18 23:41:02 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-09-18 23:41:02 +0900 |
commit | 4daa093290babb6964f0a6dd008a27bb38973213 (patch) | |
tree | 72fb303210cd8a39e1c165faf0d498013c05f348 /files/ko/web/javascript/reference/classes/constructor/index.html | |
parent | b128c3c5fcc78e87c34400411da758435b5101a3 (diff) | |
download | translated-content-4daa093290babb6964f0a6dd008a27bb38973213.tar.gz translated-content-4daa093290babb6964f0a6dd008a27bb38973213.tar.bz2 translated-content-4daa093290babb6964f0a6dd008a27bb38973213.zip |
Update classes/constructor (#2488)
* Rename html to md
* Update classes/constructor
Diffstat (limited to 'files/ko/web/javascript/reference/classes/constructor/index.html')
-rw-r--r-- | files/ko/web/javascript/reference/classes/constructor/index.html | 128 |
1 files changed, 0 insertions, 128 deletions
diff --git a/files/ko/web/javascript/reference/classes/constructor/index.html b/files/ko/web/javascript/reference/classes/constructor/index.html deleted file mode 100644 index f07dbd43b9..0000000000 --- a/files/ko/web/javascript/reference/classes/constructor/index.html +++ /dev/null @@ -1,128 +0,0 @@ ---- -title: constructor -slug: Web/JavaScript/Reference/Classes/constructor -tags: - - Classes - - ECMAScript 2015 - - JavaScript - - Reference -translation_of: Web/JavaScript/Reference/Classes/constructor ---- -<div>{{jsSidebar("Classes")}}</div> - -<p><strong><code>constructor</code></strong> 메서드는 {{jsxref("Statements/class", "class")}} 내에서 객체를 생성하고 초기화하기 위한 특별한 메서드입니다.</p> - -<div>{{EmbedInteractiveExample("pages/js/classes-constructor.html")}}</div> - - - -<h2 id="구문">구문</h2> - -<pre class="syntaxbox">constructor([<em>arguments</em>]) { ... } -</pre> - -<h2 id="설명">설명</h2> - -<p>클래스는 <code>constructor</code>라는 이름을 가진 특별한 메서드를 하나씩만 가질 수 있습니다. 두 개 이상의 <code>constructor</code> 메서드는 {{jsxref("SyntaxError")}}를 유발합니다.</p> - -<p>생성자 메서드는 {{jsxref("Operators/super", "super")}} 키워드를 사용하여 상위 클래스의 생성자 메서드를 호출할 수 있습니다.</p> - -<p>생성자 메서드를 지정하지 않은 경우엔 기본 생성자 메서드를 사용합니다.</p> - -<h2 id="예제">예제</h2> - -<h3 id="constructor_메서드_사용하기"><code>constructor</code> 메서드 사용하기</h3> - -<pre class="brush: js">class Square extends Polygon { - constructor(length) { - // length로 다각형의 넓이와 높이를 정의하기 위해 부모클래스의 생성자를 호출합니다. - super(length, length); - // Note: 파생 클래스에서, 'this'를 사용하기 전에는 반드시 super()를 - // 호출하여야 합니다. 그렇지 않을 경우 참조에러가 발생합니다. - this.name = 'Square'; - } - - get area() { - return this.height * this.width; - } - - set area(value) { - this.area = value; - } -}</pre> - -<h3 id="다른예제">다른예제</h3> - -<pre class="brush: js">class Polygon { - constructor() { - this.name = "Polygon"; - } -} - -class Square extends Polygon { - constructor() { - super(); - } -} - -class Rectangle {} - -Object.setPrototypeOf(Square.prototype, Rectangle.prototype); - -console.log(Object.getPrototypeOf(Square.prototype) === Polygon.prototype); //false -console.log(Object.getPrototypeOf(Square.prototype) === Rectangle.prototype); //true - -let newInstance = new Square(); -console.log(newInstance.name); //Polygon</pre> - -<p>여기서 <strong>Square</strong> 클래스의 프로토 타입이 변경되었지만 사각형의 새 인스턴스가 만들어 질 때 이전 기본 클래스 인 <strong>Polygon</strong>의 생성자가 호출됩니다.</p> - -<h3 id="기본_생성자">기본 생성자</h3> - -<p>만약 생성자를 지정하지 않을 경우 기본 생성자 메서드를 사용합니다. 기본 클래스(즉, 아무것도 상속하지 않는 클래스)의 기본 생성자 메서드는 다음과 같습니다.</p> - -<pre class="brush: js">constructor() {} -</pre> - -<p>파생 클래스의 경우, 기본 생성자는 다음과 같습니다.</p> - -<pre class="brush: js">constructor(...args) { - super(...args); -}</pre> - -<h2 id="명세">명세</h2> - -<table class="standard-table"> - <tbody> - <tr> - <th scope="col">명세</th> - <th scope="col">상태</th> - <th scope="col">설명</th> - </tr> - <tr> - <td>{{SpecName('ES2015', '#sec-static-semantics-constructormethod', 'Constructor Method')}}</td> - <td>{{Spec2('ES2015')}}</td> - <td>Initial definition.</td> - </tr> - <tr> - <td>{{SpecName('ESDraft', '#sec-static-semantics-constructormethod', 'Constructor Method')}}</td> - <td>{{Spec2('ESDraft')}}</td> - <td> </td> - </tr> - </tbody> -</table> - -<h2 id="브라우저_호환성">브라우저 호환성</h2> - - - -<p>{{Compat("javascript.classes.constructor")}}</p> - -<h2 id="같이_보기">같이 보기</h2> - -<ul> - <li>{{jsxref("Operators/super", "super")}}</li> - <li><a href="/ko/docs/Web/JavaScript/Reference/Operators/class"><code>class</code> 표현식</a></li> - <li><a href="/ko/docs/Web/JavaScript/Reference/Statements/class"><code>class</code> 선언문</a></li> - <li><a href="/ko/docs/Web/JavaScript/Reference/Classes">클래스</a></li> -</ul> |