JavaScript-Closures erklärt

JavaScript-Closures erklärt

1. Was ist ein Abschluss?

Abschluss: Die Kombination einer Funktion und des Zustands der Umgebung, in der die Funktion deklariert wird.
Das heißt, eine Funktion kann auf die Variablen der Umgebung zugreifen, in der sie definiert ist, auch wenn sie außerhalb der Umgebung aufgerufen wird, in der sie definiert ist.

Mithilfe von Closures können Sie Daten mit Funktionen verknüpfen, die diese Daten verarbeiten.

Zum Beispiel:

Funktion foo() {
	sei a = 1;
	return Funktion() {
		konsole.log(a);
	}
}
sei foo1 = foo();
foo1() // Ausgabe 1

Dies ist ein Beispiel für einen Abschluss. In foo wird eine Funktion zurückgegeben, und diese Funktion hat einen Abschluss, der den internen Gültigkeitsbereich von foo abdeckt, also a, sodass a immer erhalten bleibt und nicht erneut ausgeführt wird, wenn foo endet.

2. Die Rolle von Verschlüssen

2.1) Speicher

Was ist die Gedächtniseigenschaft von Closures?

Wenn ein Abschluss generiert wird, bleibt der Zustand der Umgebung, in der sich die Funktion befindet, immer im Speicher und wird nach dem Ende des äußeren Funktionsaufrufs nicht vom Garbage Collection-Mechanismus wiederhergestellt.

Zum Beispiel:

Funktion foo() {
    sei a = 0;
    return Funktion() {
        eine ++;
        konsole.log(a);
    }
}
sei foo1 = foo();
sei foo2 = foo();
foo1(); // 1
foo2(); // 1
foo2(); // 2
foo1(); // 2

Bildbeschreibung hier einfügen

Da a Teil des Closure ist, wird der Umgebungszustand von a beim Generieren des Closures im Speicher beibehalten und nach dem Ende des äußeren Funktionsaufrufs nicht gelöscht. Wenn foo1 verwendet wird, erhöht sich daher der Wert von a im Speicher um 1.
Dann sind die von foo1 und foo2 erzeugten Verschlüsse zwei unabhängige Verschlüsse, die sich gegenseitig nicht beeinflussen. Wenn foo2 also zum zweiten Mal aufgerufen wird, addiert es zum Ergebnis seines ersten Aufrufs 1.

2.2) Simulation privater Variablen

Stellen Sie sicher, dass eine Variable nur mit angegebenen Operationen bearbeitet werden kann.

Zum Beispiel :

Funktion foo() {
	sei A = 0;
	zurückkehren {
	    getA : Funktion() {
	        Rückgabe A;
	    }, 
	    hinzufügen: Funktion() {
	        Eine A++;
	    },
	    del : Funktion() {
	        A --;
	    }
	}
}
sei foo1 = foo();
console.log(foo1.getA()); // 0
foo1.add();
konsole.log(foo1.getA()); // 1
foo1.del();
console.log(foo1.getA()); // 0

Bildbeschreibung hier einfügen

Durch die Schließung wird sichergestellt, dass A nur den angegebenen Additions- und Subtraktionsoperationen unterzogen werden kann.

3. Hinweise zu Schließungen

Closures sollten nicht missbraucht werden, da sie sonst aufgrund übermäßiger Speichernutzung zu Leistungsproblemen auf der Webseite und sogar zu Speicherlecks führen können.

Zusammenfassen

Dieser Artikel endet hier. Ich hoffe, er kann Ihnen helfen. Ich hoffe auch, dass Sie mehr Inhalt auf 123WORDPRESS.COM lesen können!

Das könnte Sie auch interessieren:
  • Lassen Sie uns ausführlich über die Rolle von Closures in JS sprechen
  • Detaillierte Erklärung des Prinzips und der Funktion des JavaScript-Closures
  • Erweiterte Closures in JavaScript erklärt
  • Details zum JavaScript-Abschluss
  • Lassen Sie uns lernen, was Javascript-Closures sind

<<:  Darstellung von Eigenschaften wie OffsetWidth, ClientWidth, ScrollWidth, ScrollTop, ScrollLeft usw.

>>:  Zusammenfassung der Updates und gefundenen Probleme des Docker Consul-Containerdienstes

Artikel empfehlen

Beispielcode zur Implementierung eines 3D-Text-Hover-Effekts mit CSS3

In diesem Artikel wird der Beispielcode von CSS3 ...

So überwachen Sie die Windows-Leistung auf Zabbix

Hintergrundinformationen Ich habe kürzlich einige...

Zusammenfassung der Tipps zur Verwendung von coalesce() in MySQL

Vorwort Kürzlich habe ich zufällig MySQLs Coalesc...

Eine kurze Diskussion über Shallow Copy und Deep Copy in JavaScript

Inhaltsverzeichnis 1. Direkte Zuordnung 2. Oberfl...

...

Best Practices zum Teilen von React-Code

Wenn ein Projekt eine gewisse Komplexität erreich...

So verwenden Sie das Datums-Plugin vue-bootstrap-datetimepicker in vue-cli 3

Nachfragehintergrund In letzter Zeit plane ich, V...

Untersuchung des Wertes des Positionsattributs in CSS (Zusammenfassung)

Das CSS-Positionsattribut gibt den Positionierung...

JS realisiert einfachen Bildkarusselleffekt

In diesem Artikel wird der spezifische JS-Code zu...