⊗jsOpIhPPP 36 of 60 menu

JavaScript OOP에서 상속 시 발생하는 private 속성의 문제점

private 속성이 상속되지 않는다는 점은 예상치 못한 문제를 야기할 수 있습니다. 예제를 통해 살펴보겠습니다. 다음과 같은 private 속성을 가진 부모 클래스가 있다고 가정해 봅시다:

class User { #age; setAge(age) { this.#age = age; } getAge() { return this.#age; } }

자식 클래스에서 나이를 1 증가시키는 메서드를 만들려고 한다고 가정해 봅시다. 그러나 부모의 private 속성을 수정하려는 시도는 오류를 발생시킵니다:

class Student extends User { incAge() { this.#age++; // 오류 } }

자식 클래스 내에서 private 속성 #age를 선언하면 오류가 사라집니다:

class Student extends User { #age; incAge() { this.#age++; } }

바로 여기에 함정이 숨어 있습니다! 사실 우리는 두 개의 private 속성을 생성한 것입니다: 하나는 부모에, 다른 하나는 자식에. 그리고 이 둘은 완전히 독립적으로 동작합니다. 이는 부모의 메서드들은 자신의 속성을 변경하고, 자식의 메서드들은 자신의 속성을 변경한다는 것을 의미합니다.

이 문제는 사실 해결 방법이 있습니다. 단순히 부모의 private 속성을 부모의 메서드를 통해 조작하면 됩니다. 이를 바탕으로 코드를 다시 작성해 봅시다:

class Student extends User { incAge() { let age = this.getAge(); age++; this.setAge(age); } }

다음과 같이 간략화할 수 있습니다:

class Student extends User { incAge() { this.setAge(++this.getAge()); } }

다음 코드에서 자식 클래스는 부모 클래스의 메서드를 재정의합니다. 이 코드의 문제점을 수정하세요:

class User { #name; setName(name) { this.#name = name; } getName() { return this.#name; } } class Employee extends User { setName(name) { if (name.length > 0) { this.#name = name; } } }
한국어
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақКыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
우리는 웹사이트 운영, 분석 및 개인화를 위해 쿠키를 사용합니다. 데이터 처리는 개인정보 처리방침에 따라 이루어집니다.
모두 수락 설정 거부