Funktionen mit ES6-Klassen erweitern: „Dies“ und Schließungstricks verstehen
Das Erweitern spezieller Objekte in ES6 ermöglicht die Vererbung von Funktionen und aktiviert diese als Funktionen aufgerufen werden. Die Implementierung der Logik für solche Aufrufe erfordert jedoch eine sorgfältige Berücksichtigung der „this“-Referenz.
Standardmäßig zeigt „this“ auf die Instanz selbst, wenn eine Methode für eine Klasseninstanz aufgerufen wird. Wenn eine Funktion jedoch direkt aufgerufen wird, bezieht sich „this“ auf das globale Objekt (z. B. Fenster). Um dieses Problem anzugehen, haben wir zwei Möglichkeiten:
1. Daten im Konstruktor fest codieren:
Der Aufruf „super“ kann den Funktionskonstruktor aufrufen und eine Codezeichenfolge erwarten. Um auf Instanzdaten zuzugreifen, können wir sie fest codieren:
class Smth extends Function { constructor(x) { super("return " + JSON.stringify(x) + ";"); } }
2. Verschluss und Verschluss-Wrapper:
Für eine flexiblere Lösung müssen wir einen Abschluss erstellen, der der zurückgegebenen Funktion Instanzdaten zuweist:
class Smth extends Function { constructor(x) { function smth() { return x; } Object.setPrototypeOf(smth, Smth.prototype); return smth; } }
Um diese Funktionalität zu abstrahieren, haben wir kann eine „ExtensibleFunction“-Klasse einführen:
class ExtensibleFunction extends Function { constructor(f) { return Object.setPrototypeOf(f, new.target.prototype); } }
Unterklassen können dann von ExtensibleFunction erben:
class Smth extends ExtensibleFunction { constructor(x) { super(function() { return x; }); } }
Die Verwendung von Pfeilfunktionen oder benannten Funktionen kann ebenfalls alternative Ansätze bieten, obwohl sie sich darin unterscheiden können ihr Vererbungsverhalten.
Das obige ist der detaillierte Inhalt vonSo erweitern Sie Funktionen in ES6-Klassen: Navigieren in „diesem' und Abschlusstechniken. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!