


So implementieren Sie Lazy Loading in JavaScript-Anwendungen_Grundkenntnisse
Ob einfach oder komplex, Webanwendungen bestehen aus einigen HTML-, JavaScript- und CSS-Dateien. Normalerweise verwenden Entwickler JavaScript-Frameworks von Drittanbietern wie JQuery, Knockout, Underscore usw., um die Entwicklungsgeschwindigkeit zu verbessern. Da diese JavaScript-Frameworks für bestimmte Zwecke entwickelt und „bewährt“ wurden, ist es sinnvoller, sie direkt zu verwenden, als die erforderlichen Funktionen von Grund auf zu implementieren. Da jedoch die Komplexität von Anwendungen immer weiter zunimmt, wird es immer wichtiger, sauberen, kopplungsarmen und wartbaren Code zu schreiben. In diesem Artikel erkläre ich, wie das RequireJS-Framework Anwendungsentwicklern hilft, modulareren Code zu schreiben und wie es die Anwendungsleistung durch verzögertes Laden von JavaScript-Dateien verbessert.
Wir beginnen ohne das RequireJS-Framework und überarbeiten es dann im nächsten Kapitel mit RequireJS.
Die folgende HTML-Seite enthält ein
-Element mit der ID „message“. Wenn der Benutzer diese Seite besucht, werden die Bestell-ID und die Informationen zum Kundennamen angezeigt.
Die Common.JS-Datei enthält die Definitionen von zwei Modulen – Bestellung und Kunde. Die Funktion showData wird mit dem Hauptteil der Seite kombiniert. Sie fügt die auszugebenden Informationen in die Seite ein, indem sie die Funktion write aufruft. Als Beispiel habe ich in der showData-Funktion die ID fest auf 1 und den Kundennamen auf Prasad fest codiert.
<!DOCTYPE html> <html> <head> <title>JavaScript NonRequireJS</title> <script src="common.js" type="text/javascript"></script> </head> <body> <strong>Display data without RequireJS</strong> <p id="message" /> <script type="text/javascript"> showData(); </script> </body> </html> Common.JS
function write(message) { document.getElementById('message').innerHTML += message + '</br>'; } function showData() { var o = new Order(1, "Prasad"); write("Order Id : " + o.id + " Customer Name : " + o.customer.name); } function Customer(name) { this.name = name; return this; } function Order(id, customerName) { this.id = id; this.customer = new Customer(customerName); return this; }Öffnen Sie diese Seite in Ihrem Browser. Sie sehen die folgenden Informationen.
Obwohl der obige Code die Ausgabe anzeigen kann, gibt es dennoch einige Probleme:
Die Common.JS-Datei enthält alle Funktionen, die definiert werden müssen (Schreiben, Daten anzeigen), und die Module (Bestellung, Kunde) sind schwer zu warten und wiederzuverwenden. Wenn Sie die Schreibfunktion auf anderen Seiten wiederverwenden und auf die obige JavaScript-Datei verweisen möchten, haben Sie auch andere Funktionen und Module importiert, die für diese Seite möglicherweise nicht benötigt werden.
- Das Order-Modul (oder „Klasse“ im objektorientierten Sinne) erstellt während des Initialisierungsprozesses eine Instanz des Customer-Moduls. Das bedeutet, dass das Bestellmodul vom Kundenmodul abhängig ist. Die enge Kopplung zwischen diesen Modulen erschwert die Umgestaltung und Wartung bei zukünftigen Optimierungen.
- Immer wenn der Client diese Seite anfordert, wird die Common.JS-Datei in das DOM geladen. Obwohl wir im obigen Beispiel nur Informationen auf der Seite ausgeben müssen, laden wir dennoch die unnötigen Module (Kunde, Bestellung) in den Speicher. Das Laden unnötiger Anwendungsressourcen (JavaScript, CSS, Bilddateien usw.) kann die Anwendungsleistung beeinträchtigen.
- Die Module in der Common.JS-Datei können in verschiedene JavaScript-Dateien unterteilt werden. Wenn die Anwendung jedoch immer komplexer wird, ist es schwierig, die Abhängigkeiten zwischen JavaScript-Dateien und die Ladereihenfolge der zu ladenden Dateien zu beurteilen . .
- Das RequireJS-Framework verarbeitet Abhängigkeiten zwischen JavaScript-Dateien und lädt sie nach Bedarf nacheinander.
Schauen wir uns nun den überarbeiteten Code an. Der folgende HTML-Code verweist auf die Datei Require.JS. Das data-main-Attribut definiert den einzigen Einstiegspunkt für diese Seite. Im folgenden Szenario wird RequireJS angewiesen, Main.js beim Start zu laden.
<!DOCTYPE html> <html> <head> <title>JavaScript RequireJS</title> <script src="Require.Js" type="text/javascript" data-main="Main.js"></script> </head> <body> <strong>Display data using RequireJS</strong> <p id="message" /> </body> </html>
Da diese Datei über das data-main-Attribut angegeben wurde, lädt RequireJS sie so schnell wie möglich. Diese Datei nutzt Funktionen des RequireJS-Frameworks, um Abhängigkeiten zu anderen JavaScript-Dateien zu ermitteln und zu definieren. Im folgenden Codeausschnitt stellt der erste Parameter die Abhängigkeit dar (abhängig von der Order.JS-Datei) und der zweite Parameter ist eine Rückruffunktion. RequireJS analysiert alle Abhängigkeiten, lädt sie und führt dann diese Rückruffunktion aus. Bitte beachten Sie, dass der Wert des ersten Parameters (Order) mit dem Dateinamen (Order.JS) übereinstimmen muss.
require(["Order"], function (Order) { var o = new Order(1, "Prasad"); write(o.id + o.customer.name); });
Das RequireJS-Framework bietet eine einfache Möglichkeit, Abhängigkeiten zwischen JavaScript-Dateien zu definieren und zu verwalten. Die Definitionsfunktion im folgenden Code deklariert, dass Customer.JS geladen werden muss, bevor die Callback-Funktion „Order“ verarbeitet wird.
define(["Customer"], function (Customer) { function Order(id, custName) { this.id = id; this.customer = new Customer(custName); } return Order; } );
Diese Datei ist nicht von anderen JavaScript-Dateien abhängig, daher ist der Wert des ersten Parameters der Definitionsfunktion ein leeres Array.
Okay, jetzt öffnen Sie diese Anwendung mit Ihrem Browser, Sie werden die folgende Ausgabe sehen. Beachten Sie, dass RequireJS nur erforderliche JavaScript-Dateien lädt.
Zusammenfassung
In diesem Artikel analysieren wir, wie das RequireJS-Framework Abhängigkeiten zwischen JavaScript-Dateien verarbeitet und diese nach Bedarf lädt. Es hilft Entwicklern, Code zu schreiben, der lockerer gekoppelt, modularer und wartbarer ist.
Vielen Dank
Quellcode herunterladen: Lazy Loading mit RequireJS (Prasad Honrao, Codetails)

Ja, der Motorkern von JavaScript ist in C. 1) Die C -Sprache bietet eine effiziente Leistung und die zugrunde liegende Steuerung, die für die Entwicklung der JavaScript -Engine geeignet ist. 2) Die V8-Engine als Beispiel wird sein Kern in C geschrieben, wobei die Effizienz und objektorientierte Eigenschaften von C kombiniert werden.

JavaScript ist das Herzstück moderner Websites, da es die Interaktivität und Dynamik von Webseiten verbessert. 1) Es ermöglicht die Änderung von Inhalten, ohne die Seite zu aktualisieren, 2) Webseiten durch DOMAPI zu manipulieren, 3) Komplexe interaktive Effekte wie Animation und Drag & Drop, 4) die Leistung und Best Practices optimieren, um die Benutzererfahrung zu verbessern.

C und JavaScript erreichen die Interoperabilität durch WebAssembly. 1) C -Code wird in das WebAssembly -Modul zusammengestellt und in die JavaScript -Umgebung eingeführt, um die Rechenleistung zu verbessern. 2) In der Spieleentwicklung kümmert sich C über Physik -Engines und Grafikwiedergabe, und JavaScript ist für die Spiellogik und die Benutzeroberfläche verantwortlich.

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.

Python eignet sich besser für Datenwissenschaft und Automatisierung, während JavaScript besser für die Entwicklung von Front-End- und Vollstapel geeignet ist. 1. Python funktioniert in Datenwissenschaft und maschinellem Lernen gut und unter Verwendung von Bibliotheken wie Numpy und Pandas für die Datenverarbeitung und -modellierung. 2. Python ist prägnant und effizient in der Automatisierung und Skripten. 3. JavaScript ist in der Front-End-Entwicklung unverzichtbar und wird verwendet, um dynamische Webseiten und einseitige Anwendungen zu erstellen. 4. JavaScript spielt eine Rolle bei der Back-End-Entwicklung durch Node.js und unterstützt die Entwicklung der Vollstapel.

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.

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.

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.


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

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

Herunterladen der Mac-Version des Atom-Editors
Der beliebteste Open-Source-Editor

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

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.

EditPlus chinesische Crack-Version
Geringe Größe, Syntaxhervorhebung, unterstützt keine Code-Eingabeaufforderungsfunktion
