Heim >Web-Frontend >js-Tutorial >Wie wirken sich Klammern, Anführungszeichen und keine Anführungszeichen auf das Verhalten von „setTimeout' in JavaScript aus?

Wie wirken sich Klammern, Anführungszeichen und keine Anführungszeichen auf das Verhalten von „setTimeout' in JavaScript aus?

Barbara Streisand
Barbara StreisandOriginal
2024-12-29 05:35:10523Durchsuche

How Do Parentheses, Quotes, and No Quotes Affect `setTimeout` Behavior in JavaScript?

Verstehen der Unterschiede bei der Verwendung von setTimeout

In JavaScript können Sie mit setTimeout die Ausführung einer Funktion nach einer bestimmten Verzögerung planen. Es gibt mehrere Möglichkeiten, setTimeout mit unterschiedlicher Syntax zu verwenden.

1. mit Klammern:

setTimeout(() => console.log("Callback"), 1000);

In diesem Szenario wird eine anonyme Pfeilfunktion als Rückruf übergeben, und die Klammern um sie herum zeigen an, dass sie sofort ausgeführt und als Referenz an setTimeout übergeben wird.

2. Ohne Anführungszeichen oder Klammern:

setTimeout(callbackFunction, 1000);

Hier ist callbackFunction eine vordefinierte Funktion, die als Rückruf ohne Anführungszeichen oder Klammern übergeben wird. Die Funktionsreferenz wird ausgeführt, wenn die Verzögerung abgeschlossen ist.

3. Nur Anführungszeichen verwenden:

setTimeout("alertMsg()", 1000);

Von dieser Verwendung wird dringend abgeraten, da sie zu Sicherheitslücken führen kann. Dazu muss die Funktion als globale Variable definiert sein und eine Zeichenfolge verwendet werden, die den Funktionsnamen enthält. Diese Zeichenfolge wird dann ausgewertet und als Skript ausgeführt.

Hauptunterschiede:

  • Klammern: Geben die sofortige Ausführung der Rückruffunktion an , und übergeben Sie es als Referenz.
  • Zitate: Erlauben Sie eine Zeichenfolge, die Folgendes enthält Funktionsname, der ausgeführt werden soll, aber dies ist unsicher.
  • Keine Anführungszeichen oder Klammern: Übergeben Sie die Funktionsreferenz direkt als Rückruf.

Das obige ist der detaillierte Inhalt vonWie wirken sich Klammern, Anführungszeichen und keine Anführungszeichen auf das Verhalten von „setTimeout' in JavaScript aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
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