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');Dies streichelt die Ausführung der
-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!

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 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.

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

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.

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.

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.

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


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

Dreamweaver CS6
Visuelle Webentwicklungstools

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

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
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

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.
