비정적 ES6 클래스 메서드에서 정적 메서드 호출
ES6 클래스로 작업할 때 다음에서 정적 메서드에 액세스해야 할 수도 있습니다. 비정적 클래스 메서드 내에서. 이를 달성하기 위한 두 가지 주요 옵션이 있습니다: 생성자를 사용하거나 클래스 이름을 직접 참조하는 것입니다. 두 방법 모두 기술적으로 실행 가능하지만 재정의된 정적 메서드를 사용하는 상속의 맥락에서 서로 다른 동작을 나타냅니다.
옵션 1: 생성자 사용
class SomeObject { constructor(n) { this.n = n; } static print(n) { console.log(n); } printN() { this.constructor.print(this.n); } }
여기서 예를 들어 정적 메소드 print는 생성자 this.constructor를 통해 액세스됩니다. 이 접근 방식을 사용하면 클래스가 확장되고 하위 클래스에서 정적 메서드가 재정의되는 경우에도 올바른 정적 메서드가 호출됩니다.
옵션 2: 클래스 이름을 직접 참조
class SomeObject { constructor(n) { this.n = n; } static print(n) { console.log(n); } printN() { SomeObject.print(this.n); } }
이 경우 정적 메소드 print는 클래스 이름으로 참조됩니다. 이 메서드는 기본적으로 정적이며 상속 관계에 관계없이 항상 클래스에 정의된 원래 값을 반환합니다.
상속 및 재정의 고려 사항
생성자 사용 여부 선택 또는 그림과 같이 상속 및 재정의된 정적 메서드를 처리할 때 클래스 이름이 직접적으로 중요해집니다. 아래:
class Super { static whoami() { return "Super"; } lognameA() { console.log(Super.whoami()); } lognameB() { console.log(this.constructor.whoami()); } } class Sub extends Super { static whoami() { return "Sub"; } }
사례 1: Super.whoami() 사용
사례 2: this.constructor.whoami() 사용
이러한 시나리오의 동작은 정적 메서드가 실제로 재정의되었는지 여부에 따라 달라질 수 있습니다. 클래스 이름을 통해 정적 속성을 참조하면 진정한 정적 동작이 제공되는 반면 this.constructor를 사용하면 동적 디스패치 및 상속을 고려할 수 있습니다. 적절한 방법을 선택하는 것은 주어진 상황에서 원하는 동작에 따라 다릅니다.
위 내용은 비정적 ES6 클래스 메서드에서 정적 메서드를 호출하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!