"Si un trabajador quiere hacer bien su trabajo, primero debe afilar sus herramientas." - Confucio, "Las Analectas de Confucio. Lu Linggong"
Página delantera > Programación > ¿Se puede llamar a un constructor de clases sin \'new\' en ES6?

¿Se puede llamar a un constructor de clases sin \'new\' en ES6?

Publicado el 2024-11-07
Navegar:567

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

Llamar al constructor de clases sin nueva palabra clave en ES6

Dada la definición de clase:

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

No es posible llamar directamente al constructor de la clase sin la nueva palabra clave. Esto se debe a que las clases en ES6 tienen inherentemente una función constructora que se invoca cuando se llama a la clase.

Invocar una clase sin resultados nuevos genera un error:

Cannot call a class as a function

Este mensaje de error indica claramente que el constructor de la clase solo se puede llamar con el nuevo operador, que es necesario para crear una nueva instancia de la clase.

Para superar esta limitación, considere los siguientes enfoques :

  • Utilice una función normal en su lugar:
function Foo(x) {
  this.x = x;
  this.hello = function() {
    return `hello ${this.x}`;
  }
}
  • Llame siempre a la clase con new:
(new Foo("world")).hello(); // "hello world"
  • Envuelve la clase en una función y llama con new:
var FooWrapper = function(...args) { return new Foo(...args) };
FooWrapper("world").hello(); // "hello world"
Último tutorial Más>

Descargo de responsabilidad: Todos los recursos proporcionados provienen en parte de Internet. Si existe alguna infracción de sus derechos de autor u otros derechos e intereses, explique los motivos detallados y proporcione pruebas de los derechos de autor o derechos e intereses y luego envíelos al correo electrónico: [email protected]. Lo manejaremos por usted lo antes posible.

Copyright© 2022 湘ICP备2022001581号-3