Heim > Web-Frontend > js-Tutorial > Hauptteil

Können Sie in ES6 einen Klassenkonstruktor ohne „new' aufrufen?

Susan Sarandon
Freigeben: 2024-10-26 01:55:02
Original
303 Leute haben es durchsucht

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

Klassenkonstruktor ohne neues Schlüsselwort in ES6 aufrufen

Angesichts der Klassendefinition:

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

Es ist nicht möglich um den Klassenkonstruktor direkt ohne das neue Schlüsselwort aufzurufen. Dies liegt daran, dass Klassen in ES6 von Natur aus über eine Konstruktorfunktion verfügen, die aufgerufen wird, wenn die Klasse aufgerufen wird.

Das Aufrufen einer Klasse ohne neue Ergebnisse führt zu einem Fehler:

Cannot call a class as a function
Nach dem Login kopieren

Diese Fehlermeldung weist eindeutig darauf hin dass der Klassenkonstruktor nur mit dem neuen Operator aufgerufen werden kann, der zum Erstellen einer neuen Instanz der Klasse erforderlich ist.

Um diese Einschränkung zu überwinden, ziehen Sie die folgenden Ansätze in Betracht:

  • Verwenden Sie stattdessen eine reguläre Funktion:
function Foo(x) {
  this.x = x;
  this.hello = function() {
    return `hello ${this.x}`;
  }
}
Nach dem Login kopieren
  • Rufen Sie die Klasse immer mit new auf:
(new Foo("world")).hello(); // "hello world"
Nach dem Login kopieren
  • Schließen Sie die Klasse in eine Funktion ein und rufen Sie sie mit new auf:
var FooWrapper = function(...args) { return new Foo(...args) };
FooWrapper("world").hello(); // "hello world"
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonKönnen Sie in ES6 einen Klassenkonstruktor ohne „new' aufrufen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!