Verzögerung, Schlaf, Pause und Warte 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
- 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.
- 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.
- 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
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
an setTimeout
Millisekunden einstellen. i * 1000
console.log('Hello'); setTimeout(1000); console.log('World');
-Anweisung und stellt sicher, dass zwischen den einzelnen Ausgaben ein ein Sekundenspunkte Intervall besteht. console.log
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
(ä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!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

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

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen











Python eignet sich besser für Anfänger mit einer reibungslosen Lernkurve und einer kurzen Syntax. JavaScript ist für die Front-End-Entwicklung mit einer steilen Lernkurve und einer flexiblen Syntax geeignet. 1. Python-Syntax ist intuitiv und für die Entwicklung von Datenwissenschaften und Back-End-Entwicklung geeignet. 2. JavaScript ist flexibel und in Front-End- und serverseitiger Programmierung weit verbreitet.

Zu den Hauptanwendungen von JavaScript in der Webentwicklung gehören die Interaktion der Clients, die Formüberprüfung und die asynchrone Kommunikation. 1) Dynamisches Inhaltsaktualisierung und Benutzerinteraktion durch DOM -Operationen; 2) Die Kundenüberprüfung erfolgt vor dem Einreichung von Daten, um die Benutzererfahrung zu verbessern. 3) Die Aktualisierung der Kommunikation mit dem Server wird durch AJAX -Technologie erreicht.

Die Anwendung von JavaScript in der realen Welt umfasst Front-End- und Back-End-Entwicklung. 1) Zeigen Sie Front-End-Anwendungen an, indem Sie eine TODO-Listanwendung erstellen, die DOM-Operationen und Ereignisverarbeitung umfasst. 2) Erstellen Sie RESTFUFFUPI über Node.js und express, um Back-End-Anwendungen zu demonstrieren.

Es ist für Entwickler wichtig, zu verstehen, wie die JavaScript -Engine intern funktioniert, da sie effizientere Code schreibt und Leistungs Engpässe und Optimierungsstrategien verstehen kann. 1) Der Workflow der Engine umfasst drei Phasen: Parsen, Kompilieren und Ausführung; 2) Während des Ausführungsprozesses führt die Engine dynamische Optimierung durch, wie z. B. Inline -Cache und versteckte Klassen. 3) Zu Best Practices gehören die Vermeidung globaler Variablen, die Optimierung von Schleifen, die Verwendung von const und lass und die Vermeidung übermäßiger Verwendung von Schließungen.

Python und JavaScript haben ihre eigenen Vor- und Nachteile in Bezug auf Gemeinschaft, Bibliotheken und Ressourcen. 1) Die Python-Community ist freundlich und für Anfänger geeignet, aber die Front-End-Entwicklungsressourcen sind nicht so reich wie JavaScript. 2) Python ist leistungsstark in Bibliotheken für Datenwissenschaft und maschinelles Lernen, während JavaScript in Bibliotheken und Front-End-Entwicklungsbibliotheken und Frameworks besser ist. 3) Beide haben reichhaltige Lernressourcen, aber Python eignet sich zum Beginn der offiziellen Dokumente, während JavaScript mit Mdnwebdocs besser ist. Die Wahl sollte auf Projektbedürfnissen und persönlichen Interessen beruhen.

Sowohl Python als auch JavaScripts Entscheidungen in Entwicklungsumgebungen sind wichtig. 1) Die Entwicklungsumgebung von Python umfasst Pycharm, Jupyternotebook und Anaconda, die für Datenwissenschaft und schnelles Prototyping geeignet sind. 2) Die Entwicklungsumgebung von JavaScript umfasst Node.JS, VSCODE und WebPack, die für die Entwicklung von Front-End- und Back-End-Entwicklung geeignet sind. Durch die Auswahl der richtigen Tools nach den Projektbedürfnissen kann die Entwicklung der Entwicklung und die Erfolgsquote der Projekte verbessert werden.

C und C spielen eine wichtige Rolle in der JavaScript -Engine, die hauptsächlich zur Implementierung von Dolmetschern und JIT -Compilern verwendet wird. 1) C wird verwendet, um JavaScript -Quellcode zu analysieren und einen abstrakten Syntaxbaum zu generieren. 2) C ist für die Generierung und Ausführung von Bytecode verantwortlich. 3) C implementiert den JIT-Compiler, optimiert und kompiliert Hot-Spot-Code zur Laufzeit und verbessert die Ausführungseffizienz von JavaScript erheblich.

JavaScript wird in Websites, mobilen Anwendungen, Desktop-Anwendungen und serverseitigen Programmierungen häufig verwendet. 1) In der Website -Entwicklung betreibt JavaScript DOM zusammen mit HTML und CSS, um dynamische Effekte zu erzielen und Frameworks wie JQuery und React zu unterstützen. 2) Durch reaktnatives und ionisches JavaScript wird ein plattformübergreifendes mobile Anwendungen entwickelt. 3) Mit dem Elektronenframework können JavaScript Desktop -Anwendungen erstellen. 4) Node.js ermöglicht es JavaScript, auf der Serverseite auszuführen und unterstützt hohe gleichzeitige Anforderungen.
