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 Foo("world")).hello(); // "hello world"
var FooWrapper = function(...args) { return new Foo(...args) }; FooWrapper("world").hello(); // "hello world"
부인 성명: 제공된 모든 리소스는 부분적으로 인터넷에서 가져온 것입니다. 귀하의 저작권이나 기타 권리 및 이익이 침해된 경우 자세한 이유를 설명하고 저작권 또는 권리 및 이익에 대한 증거를 제공한 후 이메일([email protected])로 보내주십시오. 최대한 빨리 처리해 드리겠습니다.
Copyright© 2022 湘ICP备2022001581号-3