Heim > Web-Frontend > js-Tutorial > Anonyme JavaScript-Funktionen imitieren Scope_Javascript-Fähigkeiten auf Blockebene

Anonyme JavaScript-Funktionen imitieren Scope_Javascript-Fähigkeiten auf Blockebene

WBOY
Freigeben: 2016-05-16 15:26:12
Original
1636 Leute haben es durchsucht

Anonyme Funktion

Funktion ist das flexibelste Objekt in JavaScript. Hier erklären wir nur die Verwendung seiner anonymen Funktionen.

Anonyme Funktion: Es handelt sich um eine Funktion ohne Funktionsnamen.

Die Definition der Funktion stellt zunächst kurz die Definition der Funktion vor, die grob in drei Arten unterteilt werden kann

Der erste Typ: Dies ist auch der konventionellste

function double(x){
  return 2 * x;  
}
Nach dem Login kopieren

Die zweite Methode: Diese Methode verwendet den Funktionskonstruktor und behandelt sowohl die Parameterliste als auch den Funktionskörper als Zeichenfolgen. Dies ist sehr unpraktisch und wird nicht empfohlen.

var double = new Function('x', 'return 2 * x;');
Nach dem Login kopieren

Der dritte Typ:

var double = function(x) { return 2* x; }
Nach dem Login kopieren

Beachten Sie, dass die Funktion auf der rechten Seite von „=" eine anonyme Funktion ist. Nach dem Erstellen der Funktion wird die Funktion der Variablen quadrat zugewiesen.

In JavaScript gibt es kein Konzept für den Bereich auf Blockebene. Mit anderen Worten: Variablen, die in Anweisungen auf Blockebene definiert sind, werden tatsächlich in der enthaltenden Funktion (externe Funktion) und nicht in der Anweisung erstellt.

function outputNumber(count){ 
  for(var i=0;i<1000;i++){ 
    alert(i); 
  } 
  alert(i);  //count 
} 
Nach dem Login kopieren

Für diese Funktion in Sprachen wie Java und C# wird die Variable i nur in der for-Schleifenanweisung definiert. Wenn die Schleife endet, wird ich zerstört. In JavaScript ist die Variable i jedoch im Aktivitätsobjekt „outputNumber()“ definiert, sodass innerhalb der Funktion auf sie zugegriffen werden kann, sobald sie definiert ist. Selbst wenn Sie dieselbe Variable erneut deklarieren, wird ihr Wert nicht geändert.

function outputNumber(count){ 
  for(var i=0;i<1000;i++){ 
    alert(i); 
  } 
  var i;   //重新声明变量 
  alert(i);  //count 
} 
Nach dem Login kopieren

Anonyme Funktionen können verwendet werden, um den Bereich auf Blockebene zu imitieren und dieses Problem zu vermeiden. Die Syntax anonymer Funktionen, die als Bereich auf Blockebene (auch privater Bereich genannt) verwendet werden, lautet wie folgt:

(function(){ 
   //这是块级作用域 
})() 
Nach dem Login kopieren

Die obige Codedefinition ruft eine anonyme Funktion auf und schließt die Funktionsdeklaration in Klammern ein, um anzuzeigen, dass es sich um einen Funktionsausdruck handelt. Ein weiteres darauf folgendes Klammerpaar ruft die Funktion sofort auf.
Wenn Sie vorübergehend einige Variablen benötigen, können Sie den privaten Bereich verwenden, zum Beispiel:

function outputNumber(count){ 
  (function(){ 
  for(var i=0;i<1000;i++){ 
    alert(i); 
  })(); 
  alert(i);  //导致一个错误 
} 
Nach dem Login kopieren

Auf diese Weise fügen wir einen privaten Bereich außerhalb der for-Schleife ein. Alle in einer anonymen Funktion definierten Variablen werden am Ende der Ausführung zerstört.

Diese Technik wird häufig außerhalb von Funktionen im globalen Bereich verwendet, um das Hinzufügen zu vieler Variablen und Funktionen zum globalen Bereich zu begrenzen.

Im Allgemeinen sollten wir versuchen, das Hinzufügen von Variablen und Funktionen zum globalen Bereich so gering wie möglich zu halten.

Dieser Ansatz kann das Problem verringern, dass Schließungen Speicher belegen, da es keinen Verweis auf die anonyme Funktion gibt und ihre Bereichskette sofort zerstört werden kann, solange die Funktion ausgeführt wird.

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
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage