Heim > Web-Frontend > js-Tutorial > Wie verhalten sich Funktionsdeklarationen innerhalb von if/else-Anweisungen in JavaScript?

Wie verhalten sich Funktionsdeklarationen innerhalb von if/else-Anweisungen in JavaScript?

Linda Hamilton
Freigeben: 2024-11-03 01:58:03
Original
427 Leute haben es durchsucht

How Do Function Declarations Behave Within if/else Statements in JavaScript?

Funktionsdeklarationen in if/else-Anweisungen

Wenn Funktionsdeklarationen in if/else-Anweisungen vorkommen, kann ihre Handhabung je nach JavaScript variieren Umfeld. Im bereitgestellten Codeausschnitt sind Funktionsdeklarationen in jedem if/else-Zweig definiert:

var abc = '';
if (1 === 0) {
  function a() {
    abc = 7;
  }
} else if ('a' === 'a') {
  function a() {
    abc = 19;
  }
} else if ('foo' === 'bar') {
  function a() {
    abc = 'foo';
  }
}
a();
document.write(abc); // Expected output: foo
Nach dem Login kopieren

Unter ECMAScript 5 (ES5) zeigt der obige Code im nicht-strikten Modus unvorhersehbares Verhalten. Verschiedene Browser und Engines behandeln Funktionsdeklarationen innerhalb von Blöcken unterschiedlich.

In ECMAScript 2015 (ES2015) und höher sind Funktionsdeklarationen jedoch innerhalb von Blöcken zulässig. Funktionsdeklarationen innerhalb solcher Blöcke sind auf den Block beschränkt. Im Codeausschnitt wird die Funktion a im innersten if-Block deklariert. Infolgedessen ist es im globalen Bereich undefiniert, was zu einem Fehler der undefinierten Funktion führt:

if ('foo' === 'bar') {
  function a() {
    abc = 'foo';
  }
}
a(); // Error: a is not defined
Nach dem Login kopieren

Für die Definition bedingter Funktionen wird empfohlen, Funktionsausdrücke anstelle von Deklarationen zu verwenden:

var a = 'foo' === 'bar' ? function() {
  abc = 'foo';
} : function() {
  abc = 19;
};
a();
document.write(abc); // Expected output: 19
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie verhalten sich Funktionsdeklarationen innerhalb von if/else-Anweisungen in JavaScript?. 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