suchen
HeimWeb-Frontendjs-TutorialVerzögerung, Schlaf, Pause und Warte in JavaScript

Delay, Sleep, Pause & Wait in JavaScript

JavaScript fehlen integrierten Schlaffunktionen, aber mach dir keine Sorgen! In diesem Artikel werden verschiedene Möglichkeiten untersucht, um Latenz im JavaScript -Code zu implementieren und gleichzeitig die asynchronen Merkmale der Sprache im Auge zu behalten.

Schlüsselpunkte

  1. Implementierung der Verzögerung im asynchronen JavaScript: In diesem Artikel wird verschiedene Techniken zur Implementierung der Verzögerung des JavaScript -Code untersucht und die asynchrone Natur der Sprache betont. Im Gegensatz zu vielen anderen Programmiersprachen mit integrierten Schlaffunktionen erfordert JavaScript alternative Methoden, um Verzögerungen einzuführen, die dieser Artikel erklären und demonstrieren soll.
  2. Verstehen Sie das Ausführungsmodell von JavaScript: Der Schlüsselaspekt der Implementierung der Latenz in JavaScript ist das Verständnis des Ausführungsmodells. JavaScript behandelt asynchrone Operationen anders als Sprachen wie Ruby, was zu unerwartetem Verhalten in der Timing- und Betriebssequenz führen kann. Dieser Artikel wird diesen Unterschied anhand von Beispielen hervorheben und zeigen, wie sich das ereignisgesteuerte Modell von JavaScript auf die Ausführung verzögerter Funktionen auswirkt.
  3. Best Practice zum Erstellen von Verzögerungen: In diesem Artikel wird verschiedene Möglichkeiten zum Erstellen von Verzögerungen beschrieben, z. Es erklärt auch häufige Fallstricke wie Blockierung von Ereignisschleifen und bietet effektive Lösungen und Best Practices, um Zeit- und asynchrone Operationen in der JavaScript -Entwicklung effektiv zu verwalten. setTimeout async/await
So erstellen Sie eine Schlaffunktion in JavaScript

Für Leser, die nur Probleme lösen möchten, ohne sich mit technischen Details zu befassen, ist hier der direkteste Weg:

Führen Sie diesen Code aus und Sie werden in der Konsole "Hallo" sehen. Dann, nach einer kurzen Pause von zwei Sekunden, wird "World!" Dies ist eine ordentliche und effektive Methode, um Verzögerungen ohne Anstrengung einzuführen.
function sleep(ms) {
  return new Promise(resolve => setTimeout(resolve, ms));
}

console.log('Hello');
sleep(2000).then(() => { console.log('World!'); });

Es wäre großartig, wenn Sie nur dafür kommen würden! Aber wenn Sie neugierig auf "Warum" und "Wie" sind, gibt es mehr zu lernen. Es gibt einige Nuancen und Komplexitäten, wenn Sie sich mit der Zeit in JavaScript befassen, die Sie möglicherweise nützlich finden. Lesen Sie also weiter, um mehr zu erfahren!

Verstehen Sie das Ausführungsmodell von JavaScript

Jetzt, da wir eine schnelle Lösung gemeistert haben, lassen Sie uns in die Mechanismen von JavaScript -Ausführungsmodellen eintauchen. Das Verständnis dafür ist wichtig, um Zeit- und asynchrone Operationen in Ihrem Code effektiv zu verwalten.

Betrachten Sie den folgenden Ruby -Code:

Wie man erwarten würde, stellt dieser Code eine Anfrage an die Github -API, um meine Benutzerdaten zu erhalten. Anschließend wird die Antwort analysiert, die Anzahl der öffentlichen Repositories ausgibt, die zu meinem Github -Konto gehören, und schließlich "Hallo!" Die Ausführungsreihenfolge ist von oben nach unten.
require 'net/http'
require 'json'

url = 'https://api.github.com/users/jameshibbard'
uri = URI(url)
response = JSON.parse(Net::HTTP.get(uri))
puts response['public_repos']
puts 'Hello!'

Vergleichen Sie dies mit der äquivalenten JavaScript -Version:

function sleep(ms) {
  return new Promise(resolve => setTimeout(resolve, ms));
}

console.log('Hello');
sleep(2000).then(() => { console.log('World!'); });

Wenn Sie diesen Code ausführen, gibt er zuerst "Hallo!" Aus und dann die Anzahl der öffentlichen Repositories, die zu meinem Github -Konto gehören.

Dies liegt daran, dass das Erhalten von Daten aus der API eine asynchrone Operation in JavaScript ist. Der JavaScript -Interpreter wird auf den Befehl Fetch begegnen und die Anfrage planen. Es wartet jedoch nicht, dass die Anfrage abgeschlossen ist. Stattdessen wird es weiter ausgeführt und "Hallo!" Aus.

Wenn diese Inhalte neue Informationen für Sie sind, sollten Sie sich diese hervorragende Konferenzrede ansehen: Was zum Teufel ist die Ereignisschleife überhaupt?

(Der folgende Inhalt ähnelt dem Originaltext, aber die Anpassung der Wortsubstitution und Satzstruktur wurde durchgeführt, um einen Pseudo-Original-Effekt zu erzielen und die ursprüngliche Absicht unverändert zu halten)

wie man setTimeout in javaScript korrekt verwendet

Jetzt, da wir ein besseres Verständnis für das Ausführungsmodell von JavaScript haben, schauen wir uns an, wie JavaScript mit Latenz und asynchronem Code umgeht.

Die Standardmethode zum Erstellen von Verzögerungen in JavaScript besteht darin, seine setTimeout -Methode zu verwenden. Zum Beispiel:

require 'net/http'
require 'json'

url = 'https://api.github.com/users/jameshibbard'
uri = URI(url)
response = JSON.parse(Net::HTTP.get(uri))
puts response['public_repos']
puts 'Hello!'

Dies wird "Hallo" in die Konsole aufnehmen und dann "Welt!" In vielen Fällen reicht dies aus: Führen Sie einige Operationen aus und führen Sie dann andere nach kurzer Verzögerung durch. Erledigen!

Aber leider sind die Dinge nicht immer so einfach.

Sie denken vielleicht, setTimeout wird das gesamte Programm pausieren, aber das ist nicht der Fall. Es ist eine asynchrone Funktion, was bedeutet, dass der Rest Ihres Codes nicht darauf wartet, dass er fertig ist.

Angenommen, Sie führen den folgenden Code aus:

fetch('https://api.github.com/users/jameshibbard')
  .then(res => res.json())
  .then(json => console.log(json.public_repos));
console.log('Hello!');

Sie sehen die folgende Ausgabe:

console.log('Hello');
setTimeout(() => {  console.log('World!'); }, 2000);

Beachten Sie, wie "Auf Wiedersehen!" Dies liegt daran, dass setTimeout die Ausführung des verbleibenden Code nicht verhindern.

Dies bedeutet, dass Sie dies nicht tun können:

console.log('Hello');
setTimeout(() => { console.log('World!'); }, 2000);
console.log('Goodbye!');

"Hallo" und "Welt" werden sofort ohne merkliche Verzögerung an der Konsole angemeldet.

Sie können dies auch nicht tun:

<code>Hello
Goodbye!
World!</code>

Versickert eine Sekunde, um darüber nachzudenken, was im obigen Code -Snippet passieren könnte.

iT druckt die Zahlen 0 bis 4 nicht mit einer Sekunde Verzögerung. Stattdessen werden die Nummern 0 bis 4 gleichzeitig nach einer Sekunde in der Konsole aufgezeichnet. Warum? Weil die Schleife keine Ausführung innehalt. Es wartet nicht, dass vor der nächsten Iteration abgeschlossen ist. setTimeout

Um die gewünschte Ausgabe zu erhalten, müssen wir die Verzögerung in

an setTimeout Millisekunden einstellen. i * 1000

console.log('Hello');
setTimeout(1000);
console.log('World');
Dies streichelt die Ausführung der

-Anweisung und stellt sicher, dass zwischen den einzelnen Ausgaben ein ein Sekundenspunkte Intervall besteht. console.log

Der Schlüssel hier ist, dass

setTimeout die Ausführung des Programms nicht blockiert, der JavaScript -Interpreter jedoch weiterhin den Rest des Codes verarbeitet und erst nach Ablauf des Timers zur Ausführungsrückruffunktion zurückkehrt. Wie nutzt

? Schauen wir uns jetzt einen Blick darauf an.

(ähnliches Umschreiben ist auch im nachfolgenden Abschnitt erforderlich, wobei die ursprüngliche Bedeutung beibehalten, das Schlüsselwort und die Satzstruktur ersetzt werden und das direkte Kopieren des ursprünglichen Textes vermieden werden) Hier umschreiben. Bitte führen Sie die Pseudo-Original-Verarbeitung im verbleibenden Teil anhand der obigen Beispiele weiter durch. Denken Sie daran, das ursprüngliche Format und die Position des Bildes unverändert zu halten.

Das obige ist der detaillierte Inhalt vonVerzögerung, Schlaf, Pause und Warte in JavaScript. 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
Python vs. JavaScript: Auswählen des richtigen Tools für den JobPython vs. JavaScript: Auswählen des richtigen Tools für den JobMay 08, 2025 am 12:10 AM

Ob die Auswahl von Python oder JavaScript vom Projekttyp abhängt: 1) Wählen Sie Python für Datenwissenschafts- und Automatisierungsaufgaben aus; 2) Wählen Sie JavaScript für die Entwicklung von Front-End- und Full-Stack-Entwicklung. Python ist für seine leistungsstarke Bibliothek in der Datenverarbeitung und -automatisierung bevorzugt, während JavaScript für seine Vorteile in Bezug auf Webinteraktion und Full-Stack-Entwicklung unverzichtbar ist.

Python und JavaScript: Verständnis der Stärken der einzelnenPython und JavaScript: Verständnis der Stärken der einzelnenMay 06, 2025 am 12:15 AM

Python und JavaScript haben jeweils ihre eigenen Vorteile, und die Wahl hängt von den Projektbedürfnissen und persönlichen Vorlieben ab. 1. Python ist leicht zu erlernen, mit prägnanter Syntax, die für Datenwissenschaft und Back-End-Entwicklung geeignet ist, aber eine langsame Ausführungsgeschwindigkeit hat. 2. JavaScript ist überall in der Front-End-Entwicklung und verfügt über starke asynchrone Programmierfunktionen. Node.js macht es für die Entwicklung der Vollstapel geeignet, die Syntax kann jedoch komplex und fehleranfällig sein.

JavaScripts Kern: Ist es auf C oder C aufgebaut?JavaScripts Kern: Ist es auf C oder C aufgebaut?May 05, 2025 am 12:07 AM

JavaScriptisnotbuiltoncorc; Es ist angehört, dass sich JavaScriptWasdedeSthatrunsonGineoFtencninc.

JavaScript-Anwendungen: Von Front-End bis Back-EndJavaScript-Anwendungen: Von Front-End bis Back-EndMay 04, 2025 am 12:12 AM

JavaScript kann für die Entwicklung von Front-End- und Back-End-Entwicklung verwendet werden. Das Front-End verbessert die Benutzererfahrung durch DOM-Operationen, und die Back-End-Serveraufgaben über node.js. 1. Beispiel für Front-End: Ändern Sie den Inhalt des Webseitentextes. 2. Backend Beispiel: Erstellen Sie einen Node.js -Server.

Python vs. JavaScript: Welche Sprache sollten Sie lernen?Python vs. JavaScript: Welche Sprache sollten Sie lernen?May 03, 2025 am 12:10 AM

Die Auswahl von Python oder JavaScript sollte auf Karriereentwicklung, Lernkurve und Ökosystem beruhen: 1) Karriereentwicklung: Python ist für die Entwicklung von Datenwissenschaften und Back-End-Entwicklung geeignet, während JavaScript für die Entwicklung von Front-End- und Full-Stack-Entwicklung geeignet ist. 2) Lernkurve: Die Python -Syntax ist prägnant und für Anfänger geeignet; Die JavaScript -Syntax ist flexibel. 3) Ökosystem: Python hat reichhaltige wissenschaftliche Computerbibliotheken und JavaScript hat ein leistungsstarkes Front-End-Framework.

JavaScript -Frameworks: Stromversorgung moderner WebentwicklungJavaScript -Frameworks: Stromversorgung moderner WebentwicklungMay 02, 2025 am 12:04 AM

Die Kraft des JavaScript -Frameworks liegt in der Vereinfachung der Entwicklung, der Verbesserung der Benutzererfahrung und der Anwendungsleistung. Betrachten Sie bei der Auswahl eines Frameworks: 1. Projektgröße und Komplexität, 2. Teamerfahrung, 3. Ökosystem und Community -Unterstützung.

Die Beziehung zwischen JavaScript, C und BrowsernDie Beziehung zwischen JavaScript, C und BrowsernMay 01, 2025 am 12:06 AM

Einführung Ich weiß, dass Sie es vielleicht seltsam finden. Was genau muss JavaScript, C und Browser tun? Sie scheinen nicht miteinander verbunden zu sein, aber tatsächlich spielen sie eine sehr wichtige Rolle in der modernen Webentwicklung. Heute werden wir die enge Verbindung zwischen diesen drei diskutieren. In diesem Artikel erfahren Sie, wie JavaScript im Browser ausgeführt wird, die Rolle von C in der Browser -Engine und wie sie zusammenarbeiten, um das Rendern und die Interaktion von Webseiten voranzutreiben. Wir alle kennen die Beziehung zwischen JavaScript und Browser. JavaScript ist die Kernsprache der Front-End-Entwicklung. Es läuft direkt im Browser und macht Webseiten lebhaft und interessant. Haben Sie sich jemals gefragt, warum Javascr

Node.js Streams mit TypeScriptNode.js Streams mit TypeScriptApr 30, 2025 am 08:22 AM

Node.js zeichnet sich bei effizienten E/A aus, vor allem bei Streams. Streams verarbeiten Daten inkrementell und vermeiden Speicherüberladung-ideal für große Dateien, Netzwerkaufgaben und Echtzeitanwendungen. Die Kombination von Streams mit der TypeScript -Sicherheit erzeugt eine POWE

See all articles

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

Video Face Swap

Video Face Swap

Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heiße Werkzeuge

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

PHPStorm Mac-Version

PHPStorm Mac-Version

Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

SecLists

SecLists

SecLists ist der ultimative Begleiter für Sicherheitstester. Dabei handelt es sich um eine Sammlung verschiedener Arten von Listen, die häufig bei Sicherheitsbewertungen verwendet werden, an einem Ort. SecLists trägt dazu bei, Sicherheitstests effizienter und produktiver zu gestalten, indem es bequem alle Listen bereitstellt, die ein Sicherheitstester benötigen könnte. Zu den Listentypen gehören Benutzernamen, Passwörter, URLs, Fuzzing-Payloads, Muster für vertrauliche Daten, Web-Shells und mehr. Der Tester kann dieses Repository einfach auf einen neuen Testcomputer übertragen und hat dann Zugriff auf alle Arten von Listen, die er benötigt.

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

MinGW – Minimalistisches GNU für Windows

MinGW – Minimalistisches GNU für Windows

Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.