Heim Web-Frontend H5-Tutorial Raid auf HTML5-Javascript-API-Erweiterung 1 – Web Worker Asynchronous Execution und zugehörige Überblick_HTML5-Tutorialfähigkeiten

Raid auf HTML5-Javascript-API-Erweiterung 1 – Web Worker Asynchronous Execution und zugehörige Überblick_HTML5-Tutorialfähigkeiten

May 16, 2016 pm 03:50 PM
web worker

Javascript-Ausführungsmechanismus
Vor HTML5 funktionierte die Ausführung von JavaScript in Browsern in einer Single-Thread-Methode, obwohl es viele Möglichkeiten gibt, Multi-Threading zu simulieren (zum Beispiel: in Javascript setinterval-Methode, setTimeout-Methode). , usw.), aber im Wesentlichen wird die Ausführung des Programms immer noch von der JavaScript-Engine im Rahmen einer Single-Thread-Planung durchgeführt. Der in HTML5 eingeführte Worker-Thread ermöglicht es der browserseitigen Javascript-Engine, gleichzeitig Javascript-Code auszuführen, wodurch eine gute Unterstützung für die browserseitige Multithread-Programmierung erreicht wird.

Mehrere Threads in Javascript – WebWorker
Web Worker in HTML5 kann in zwei verschiedene Thread-Typen unterteilt werden, einer ist ein dedizierter Thread „Dedicated Worker“ und der andere ist ein gemeinsam genutzter Thread „Shared“. Arbeitnehmer. Beide Arten von Threads dienen unterschiedlichen Zwecken.
Dedizierter Web-Worker
Ein dedizierter Worker ist mit dem Skript verbunden, das ihn erstellt hat. Er kann mit anderen Workern oder Browserkomponenten kommunizieren, aber nicht mit dem DOM. Die Bedeutung von dediziert ist meiner Meinung nach, dass dieser Thread jeweils nur eine Anforderung behandelt. Dedizierte Threads sind in verschiedenen Mainstream-Browsern außer IE implementiert und können bedenkenlos verwendet werden.
Einen Thread erstellen
Das Erstellen eines Workers ist sehr einfach. Übergeben Sie einfach den Dateinamen der JavaScript-Datei, die im Thread ausgeführt werden muss.
Thread-Kommunikation
Zur Kommunikation zwischen dem Haupt-Thread und dem Sub-Thread werden die Methoden postMessage und onmessage des Thread-Objekts verwendet. Unabhängig davon, wer Daten an wen sendet, verwendet der Absender die postMessage-Methode und der Empfänger die onmessage-Methode, um Daten zu empfangen. postMessage hat nur einen Parameter, nämlich die übertragenen Daten, und onmessage hat auch nur einen Parameter. Wenn es sich um ein Ereignis handelt, werden die empfangenen Daten über event.data abgerufen.
JSON-Daten senden
JSON wird von JS nativ unterstützt. Es ist nicht nötig, JSON umsonst zu verwenden, um komplexe Daten zu übertragen. Zum Beispiel:

Code kopieren
Der Code lautet wie folgt:

postMessage({ 'cmd': 'init', 'timestamp': Date.now()});

Fehlerbehandlung
Wenn in einem Thread ein Fehler auftritt, ist dies ein Fehler Der Ereignisrückruf wird ein Anruf sein. Der Umgang mit Fehlern ist also sehr einfach, indem das onerror-Ereignis der Thread-Instanz verknüpft wird. Diese Rückruffunktion verfügt über einen Parameter „error“, der aus drei Feldern besteht: „message“ – die Fehlermeldung; „filename“ – die Skriptdatei, in der der Fehler aufgetreten ist; „line“ – die Zeile, in der der Fehler aufgetreten ist.
Zerstöre den Thread
Verwende innerhalb des Threads die Close-Methode, um sich selbst zu zerstören. Verwenden Sie im Hauptthread außerhalb des Threads die Terminate-Methode der Thread-Instanz, um den Thread zu zerstören.
Sehen wir uns die grundlegende Funktionsweise von Threads anhand eines Beispiels an:
HTML-Code:

Code kopieren
Der Code lautet wie folgt:



web worker fibonacci function(){
var worker = new Worker('fibonacci.js');
worker.onmessage = function(event) {
console.log("Result:" event.data); >};
worker.onerror = function(error) {
console.log("Error:"
};
< /script>



Skriptdatei fibonacci.js-Code:





Code kopieren

Der Code lautet wie folgt:


/ /fibonacci.js
var fibonacci = function(n) {
return n < 2 ? n : arguments.callee(n - 1) arguments.callee(n - 2); >onmessage = function(event) { var n = parseInt(event.data, 10); postMessage(fibonacci(n)};
Put them Gehen Sie in dasselbe Verzeichnis und führen Sie die Seite Datei aus. Überprüfen Sie die Konsole. Sie können die Ergebnisse des Vorgangs sehen.
Eine weitere Sache hier ist, dass im Hauptthread das onmessage-Ereignis auf andere Weise eingehängt werden kann:





Code kopieren


Der Code lautet wie folgt:

worker.addEventListener('message', function(event) {
console.log("Result:" event.data);
}, false );

Ich persönlich halte es für sehr problematisch, daher ist es besser, onmessage direkt zu verwenden.
Andere Skriptdateien verwenden
Arbeitsthreads können die globale Methode importScripts verwenden, um andere domäneninterne Skriptdateien oder Klassenbibliotheken zu laden und zu verwenden. Folgende Verwendungen sind beispielsweise zulässig:

Kopieren Sie den Code
Der Code lautet wie folgt:

importScripts();/* importiert nichts */
importScripts('foo.js'); /* importiert nur "foo.js" */
importScripts('foo.js', 'bar .js') ;/* importiert zwei Skripte */

Nach dem Import können Sie die Methoden in diesen Dateien direkt verwenden. Schauen Sie sich online ein kleines Beispiel an:

Kopieren Sie den Code
Der Code lautet wie folgt:

/* *
* Verwenden Sie die Methode importScripts, um externe Ressourcenskripte einzuführen. Hier verwenden wir die Bibliothek des mathematischen Formelberechnungstools math_utilities.js.
* Wenn die JavaScript-Engine das Laden dieser Ressourcendatei abgeschlossen hat, fahren Sie mit der Ausführung des folgenden Codes fort. Gleichzeitig kann der folgende Code auf
*-Variablen und Methoden zugreifen und diese aufrufen, die in Ressourcendateien definiert sind.
**/
importScripts('math_utilities.js');
onmessage = function (event)
{
var first = event.data.first; var second = event .data.second;
calculate(first,second) {
//führen Sie die Berechnung durch
var common_divisor= divisor(first, second);
var common_multiple=multiple(first,second);
postMessage("Arbeit erledigt! "
"Das kleinste gemeinsame Vielfache ist " common_divisor
" und der größte gemeinsame Teiler ist " common_multiple);
}


Einige Internetnutzer im Internet dachten auch darüber nach, hier die importScripts-Methode zu verwenden, um das Problem des Vorladens von Ressourcen zu lösen (der Browser lädt die Ressource im Voraus, ohne sie zu analysieren und auszuführen). die Ressource). Der Grund ist auch sehr einfach.
Thread-Verschachtelung

Sie können auch Sub-Threads im Worker-Thread erstellen, und die verschiedenen Vorgänge sind immer noch dieselben. Synchronisierungsprobleme

Worker verfügt nicht über einen Sperrmechanismus und Multithread-Synchronisierungsprobleme können nur durch Code gelöst werden (z. B. durch das Definieren von Signalvariablen). Shared SharedWebWorker

Shared Web Worker eignet sich hauptsächlich für Probleme mit der Parallelität mehrerer Verbindungen. Da mehrere Verbindungen verarbeitet werden müssen, unterscheidet sich seine API geringfügig von der eines dedizierten Workers. Abgesehen davon haben Shared Web Worker ebenso wie dedizierte Worker keinen Zugriff auf das DOM und nur eingeschränkten Zugriff auf Formulareigenschaften. Shared Web Worker können auch nicht über das Netzwerk kommunizieren. Seitenskripte können mit gemeinsam genutzten Web-Workern kommunizieren. Im Gegensatz zu dedizierten Web-Workern (die zur Kommunikation einen impliziten Port verwenden) erfolgt die Kommunikation jedoch explizit über die Verwendung eines Portobjekts. Dies erfolgt durch Anhängen eines Nachrichtenereignishandlers .
Nach dem Empfang der ersten Nachricht vom Web-Worker-Skript hängt der freigegebene Web-Worker einen Event-Handler an den aktivierten Port an. Normalerweise führt der Handler seine eigene postMessage()-Methode aus, um eine Nachricht an den aufrufenden Code zurückzugeben, und dann generiert die start()-Methode des Ports einen gültigen Nachrichtenprozess.
Sehen Sie sich das einzige Beispiel an, das ich im Internet finden kann: Erstellen Sie einen gemeinsamen Thread, um Anweisungen zu empfangen, die von verschiedenen Verbindungen gesendet werden, und implementieren Sie dann Ihre eigene Befehlsverarbeitungslogik. Nachdem die Befehlsverarbeitung abgeschlossen ist, werden die Ergebnisse an die einzelnen Verbindungen zurückgegeben Verbindungsbenutzer.
HTML-Code:




Code kopieren
Der Code lautet wie folgt:





Beispiel für einen Shared Worker: So verwenden Sie einen Shared Worker in HTML5
<script> <br>var worker = new SharedWorker('sharedworker.js'); <br>var log = document.getElementById('response_from_worker'); <br>worker.port.addEventListener('message', function(e) { <br>//Protokollieren Sie die Antwortdaten auf der Webseite <br>log.textContent =e.data; <br>}, false); <br>worker.port.start(); <br>worker.port.postMessage('ping von der Benutzer-Webseite..'); <br>//folgende Methode sendet Benutzereingaben an sharedworker <br>Funktion postMessageToSharedWorker(input) <br>{ <br>//definiere ein JSON-Objekt, um die Anfrage zu erstellen <br>var Instructions={instruction:input.value }; <br>worker.port.postMessage(instructions); <br>} <br></script>



Beispiel für einen Shared Worker: So verwenden Sie einen Shared Worker in HTML5

Anweisungen an Shared Worker senden:





脚本文件代码:

复制代码
代码如下:

// 创建一个共享线程用于接收从不同连接发送过来的指令,指令处理完成后将结果返回到各个不同的连接用户.
var connect_number = 0;
onconnect = function(e) {
connect_number =connect_number 1;
//den ersten Port hier abrufen
var port = e.ports[0];
port.postMessage('Eine neue Verbindung! Die aktuelle Verbindungsnummer ist '
connect_number);
port.onmessage = function(e) {
//Anweisungen vom Anforderer abrufen
var inventory=e.data.instruction;
var results=execute_instruction(instruction);
port.postMessage('Anfrage: ' Anweisung ' Antwort ' Ergebnisse
' von geteiltem Worker...');
};
};
/*
* Diese Funktion wird verwendet, um die vom Anforderer gesendeten Anweisungen auszuführen
* @param-Anweisung
* @return
*/
Funktion „execute_instruction(instruction)“
{
var result_value;
//implementieren Sie hier Ihre Logik
//führen Sie die Anweisung aus...
return result_value;
}

Im obigen Beispiel für einen gemeinsamen Thread wird auf der Hauptseite, also auf jeder Benutzerverbindungsseite, ein gemeinsames Thread-Objekt erstellt und anschließend eine Methode postMessageToSharedWorker definiert, um Benutzeranweisungen an den gemeinsam genutzten Thread zu senden. Gleichzeitig wird connect_number im Codeausschnitt der Shared-Thread-Implementierung definiert, um die Gesamtzahl der Verbindungen zu diesem Shared-Thread aufzuzeichnen. Verwenden Sie anschließend den Ereignishandler onconnect, um Verbindungen von verschiedenen Benutzern zu akzeptieren und die von ihnen übergebenen Anweisungen zu analysieren. Schließlich wird eine Methode „execute_instruction“ definiert, um die Anweisungen des Benutzers auszuführen. Nachdem die Anweisung ausgeführt wurde, werden die Ergebnisse an jeden Benutzer zurückgegeben.

Hier verwenden wir nicht wie im vorherigen Beispiel den onmessage-Event-Handler des Worker-Threads, sondern eine andere Methode addEventListener. Tatsächlich sind die Implementierungsprinzipien der beiden, wie bereits erwähnt, grundsätzlich gleich, es gibt jedoch einige geringfügige Unterschiede. Wenn addEventListener zum Akzeptieren von Nachrichten von gemeinsam genutzten Threads verwendet wird, muss die Methode worker.port.start() verwendet werden Zuerst müssen Sie diesen Port aktivieren. Danach können Sie wie in einem Worker-Thread ganz normal Nachrichten empfangen und senden.
Abschlusserklärung
Dinge, die im Thread erledigt werden können:
1. Sie können setTimeout(), clearTimeout(), setInterval(), clearInterval verwenden () usw. Funktion.
2. Kann ein Navigatorobjekt verwenden.
3. Kann XMLHttpRequest zum Senden von Anfragen verwenden.
4. Web Storage kann in Threads verwendet werden.
5. Sie können self in einem Thread verwenden, um den Umfang dieses Threads zu erhalten.
Dinge, die nicht in Threads ausgeführt werden können:
1. Andere DOM/BOM-Objekte als Navigator können nicht in Threads verwendet werden, z. B. Fenster und Dokumente (wenn Sie dies tun möchten, können Sie dies nur tun). Senden von Nachrichten an den Worker-Ersteller, Bedienung über Callback-Funktion).
2. Variablen und Funktionen im Hauptthread können nicht in Threads verwendet werden.
3. Betriebsbefehle mit „Suspendierungs“-Effekten, wie z. B. Warnung usw., können nicht in Threads verwendet werden.
4. JS kann nicht domänenübergreifend in einem Thread geladen werden.
Threads verbrauchen auch Ressourcen, und die Verwendung von Threads bringt auch eine gewisse Komplexität mit sich. Wenn es also keinen guten Grund für die Verwendung zusätzlicher Threads gibt, sollten Sie diese nicht verwenden.
Praktische Referenz
Offizielle Dokumentation: http://www.whatwg.org/specs/web-apps/current-work/multipage/workers.html
WebWorker-Klassifizierungsbeschreibung: http://www.w3schools.com/html5/html5_webworkers.asp
Script House: http://www.jb51.net/w3school/html5/
WebWorker-Übersicht: https://developer.mozilla.org/en/Using_web_workers
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

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

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

So verwenden Sie Python + Flask, um Echtzeitaktualisierungen und die Anzeige von Protokollen auf Webseiten zu realisieren So verwenden Sie Python + Flask, um Echtzeitaktualisierungen und die Anzeige von Protokollen auf Webseiten zu realisieren May 17, 2023 am 11:07 AM

1. Protokollausgabe in eine Datei mithilfe des Moduls: Die Protokollierung kann ein Protokoll auf benutzerdefinierter Ebene generieren und das Protokoll auf einem angegebenen Pfad ausgeben: debug (Debug-Protokoll) = 5) {clearTimeout (Zeit) // Wenn alle Ergebnisse erhalten wurden, 10 Aufeinanderfolgende Zeiten sind leer Protokolllöschung geplante Aufgabe}return}if(data.log_type==2){//Wenn ein neues Protokoll abgerufen wird for(i=0;i

So verwenden Sie den Nginx-Webserver-Caddy So verwenden Sie den Nginx-Webserver-Caddy May 30, 2023 pm 12:19 PM

Einführung in Caddy Caddy ist ein leistungsstarker und hoch skalierbarer Webserver, der derzeit über 38.000 Sterne auf Github hat. Caddy ist in der Go-Sprache geschrieben und kann für statisches Ressourcen-Hosting und Reverse-Proxy verwendet werden. Caddy verfügt über die folgenden Hauptfunktionen: Im Vergleich zur komplexen Konfiguration von Nginx ist die ursprüngliche Caddyfile-Konfiguration sehr einfach. Sie kann die Konfiguration über die bereitgestellte AdminAPI dynamisch ändern. Sie unterstützt standardmäßig die automatisierte HTTPS-Konfiguration und kann automatisch HTTPS-Zertifikate beantragen und konfigurieren Sie sie; es kann auf Zehntausende von Websites erweitert werden, ohne dass zusätzliche Abhängigkeiten in der Go-Sprache geschrieben werden müssen; die Speichersicherheit ist besser gewährleistet. Zunächst installieren wir es direkt in CentO

Verwendung von Jetty7 für die Webserververarbeitung in der Java-API-Entwicklung Verwendung von Jetty7 für die Webserververarbeitung in der Java-API-Entwicklung Jun 18, 2023 am 10:42 AM

Verwendung von Jetty7 für die Webserververarbeitung in der JavaAPI-Entwicklung Mit der Entwicklung des Internets ist der Webserver zum Kernbestandteil der Anwendungsentwicklung geworden und steht auch im Fokus vieler Unternehmen. Um den wachsenden Geschäftsanforderungen gerecht zu werden, entscheiden sich viele Entwickler für die Verwendung von Jetty für die Webserverentwicklung, und seine Flexibilität und Skalierbarkeit sind weithin anerkannt. In diesem Artikel wird erläutert, wie Sie Jetty7 für die Webentwicklung in der JavaAPI-Entwicklung verwenden.

Echtzeitschutz vor Gesichtsblockierungsangriffen im Web (basierend auf maschinellem Lernen) Echtzeitschutz vor Gesichtsblockierungsangriffen im Web (basierend auf maschinellem Lernen) Jun 10, 2023 pm 01:03 PM

Gesichtsblockierendes Sperrfeuer bedeutet, dass eine große Anzahl von Sperrfeuern vorbeischwebt, ohne die Person im Video zu blockieren, sodass es aussieht, als würden sie hinter der Person schweben. Maschinelles Lernen erfreut sich seit mehreren Jahren großer Beliebtheit, aber viele Menschen wissen nicht, dass diese Funktionen auch in Browsern ausgeführt werden können. Dieser Artikel stellt den praktischen Optimierungsprozess in Videosperren vor diese Lösung, in der Hoffnung, einige Ideen zu öffnen. mediapipeDemo (https://google.github.io/mediapipe/) demonstriert das Implementierungsprinzip des On-Demand-Uploads mit Gesichtsblockierung. Die Hintergrundberechnung des Videoservers extrahiert den Porträtbereich im Videobildschirm und konvertiert ihn in SVG Speichern, während der Client das Video abspielt. Laden Sie SVG vom Server herunter und kombinieren Sie es mit Barrage, Portrait

So implementieren Sie die Formularvalidierung für Webanwendungen mit Golang So implementieren Sie die Formularvalidierung für Webanwendungen mit Golang Jun 24, 2023 am 09:08 AM

Die Formularvalidierung ist ein sehr wichtiger Link bei der Entwicklung von Webanwendungen. Sie kann die Gültigkeit der Daten vor dem Absenden der Formulardaten überprüfen, um Sicherheitslücken und Datenfehler in der Anwendung zu vermeiden. Die Formularvalidierung für Webanwendungen kann einfach mit Golang implementiert werden. In diesem Artikel wird erläutert, wie Sie mit Golang die Formularvalidierung für Webanwendungen implementieren. 1. Grundelemente der Formularvalidierung Bevor wir uns mit der Implementierung der Formularvalidierung befassen, müssen wir die Grundelemente der Formularvalidierung kennen. Formularelemente: Formularelemente sind

So konfigurieren Sie Nginx, um sicherzustellen, dass der FRP-Server und das Web Port 80 gemeinsam nutzen So konfigurieren Sie Nginx, um sicherzustellen, dass der FRP-Server und das Web Port 80 gemeinsam nutzen Jun 03, 2023 am 08:19 AM

Zunächst werden Sie Zweifel haben: Was ist FRP? Einfach ausgedrückt ist frp ein Intranet-Penetrationstool. Nach der Konfiguration des Clients können Sie über den Server auf das Intranet zugreifen. Jetzt hat mein Server Nginx als Website verwendet und es gibt nur einen Port 80. Was soll ich also tun, wenn der FRP-Server auch Port 80 verwenden möchte? Nach der Abfrage kann dies durch die Verwendung des Reverse-Proxys von Nginx erreicht werden. Hinzufügen: frps ist der Server, frpc ist der Client. Schritt 1: Ändern Sie die Konfigurationsdatei nginx.conf auf dem Server und fügen Sie die folgenden Parameter zu http{} in nginx.conf hinzu: server{listen80

Was sind Webstandards? Was sind Webstandards? Oct 18, 2023 pm 05:24 PM

Webstandards sind eine Reihe von Spezifikationen und Richtlinien, die vom W3C und anderen verwandten Organisationen entwickelt wurden. Sie umfassen die Standardisierung von HTML, CSS, JavaScript, DOM, Web-Zugänglichkeit und Leistungsoptimierung , Wartbarkeit und Leistung. Das Ziel von Webstandards besteht darin, die konsistente Anzeige und Interaktion von Webinhalten auf verschiedenen Plattformen, Browsern und Geräten zu ermöglichen und so ein besseres Benutzererlebnis und eine bessere Entwicklungseffizienz zu gewährleisten.

So aktivieren Sie den administrativen Zugriff über die Cockpit-Web-Benutzeroberfläche So aktivieren Sie den administrativen Zugriff über die Cockpit-Web-Benutzeroberfläche Mar 20, 2024 pm 06:56 PM

Cockpit ist eine webbasierte grafische Oberfläche für Linux-Server. Es soll vor allem neuen/erfahrenen Benutzern die Verwaltung von Linux-Servern erleichtern. In diesem Artikel besprechen wir die Cockpit-Zugriffsmodi und wie Sie den Administratorzugriff von CockpitWebUI auf das Cockpit umstellen. Inhaltsthemen: Cockpit-Eingabemodi Ermitteln des aktuellen Cockpit-Zugriffsmodus Aktivieren des Verwaltungszugriffs für das Cockpit über CockpitWebUI Deaktivieren des Verwaltungszugriffs für das Cockpit über CockpitWebUI Fazit Cockpit-Eingabemodi Das Cockpit verfügt über zwei Zugriffsmodi: Eingeschränkter Zugriff: Dies ist die Standardeinstellung für den Cockpit-Zugriffsmodus. In diesem Zugriffsmodus können Sie vom Cockpit aus nicht auf den Webbenutzer zugreifen

See all articles