"일꾼이 일을 잘하려면 먼저 도구를 갈고 닦아야 한다." - 공자, 『논어』.
첫 장 > 프로그램 작성 > ES6에서 \'new\' 없이 클래스 생성자를 호출할 수 있나요?

ES6에서 \'new\' 없이 클래스 생성자를 호출할 수 있나요?

2024-11-07에 게시됨
검색:998

 Can You Call a Class Constructor Without \'new\' in ES6?

ES6에서 새 키워드가 없는 클래스 생성자 호출

클래스 정의가 주어지면:

class Foo {
  constructor(x) {
    if (!(this instanceof Foo)) return new Foo(x);
    this.x = x;
  }
  hello() {
    return `hello ${this.x}`;
  }
}

new 키워드 없이 클래스 생성자를 직접 호출하는 것은 불가능합니다. 이는 ES6의 클래스에는 클래스가 호출될 때 호출되는 생성자 함수가 본질적으로 있기 때문입니다.

새 결과 없이 클래스를 호출하면 오류가 발생합니다.

Cannot call a class as a function

이 오류 메시지는 클래스 생성자가 클래스의 새 인스턴스를 만드는 데 필요한 new 연산자로만 호출될 수 있음을 분명히 나타냅니다.

이 제한 사항을 극복하려면 다음 접근 방식을 고려하세요. :

  • 대신 일반 함수를 사용하세요:
function Foo(x) {
  this.x = x;
  this.hello = function() {
    return `hello ${this.x}`;
  }
}
  • 항상 new:
(new Foo("world")).hello(); // "hello world"
  • 클래스를 함수로 감싸고 new로 호출합니다:
var FooWrapper = function(...args) { return new Foo(...args) };
FooWrapper("world").hello(); // "hello world"
최신 튜토리얼 더>

부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.

Copyright© 2022 湘ICP备2022001581号-3