Async vs. Defer: Optimieren des Skriptladens in HTML5
Async und Defer verstehen
Die Attribute async und defer bieten Mechanismen zur Steuerung der Lade- und Ausführungsreihenfolge externer Skripte in HTML5 Browser.
Async-Attribut
- Skripte mit Async werden beim Laden sofort ausgeführt.
- Die Ausführungsreihenfolge ist nicht garantiert. Beispielsweise kann ein später hinzugefügtes Skript vor einem früher hinzugefügten ausgeführt werden.
- Nützlich für nicht blockierende Skripte, die nicht auf andere Skriptausführungen angewiesen sind.
Attribut zurückstellen
- Skripte mit Verzögerung werden ebenfalls asynchron geladen, aber erst nach der ersten HTML-Analyse ausgeführt vollständig.
- Stellt sicher, dass die Ausführungsreihenfolge mit der Reihenfolge des Erscheinens auf der Seite übereinstimmt.
- Geeignet für Skripte, die für das Rendern der Seite nicht kritisch sind.
Auswirkungen auf die Ladegeschwindigkeit der Website
Unten im Seite:
- Das Hinzufügen von Async zu Skripten unten auf der Seite kann die Ladegeschwindigkeit leicht verbessern, da Skripte gleichzeitig geladen werden können.
Oben die Seite:
- Verschieben von Skripten mit Async oder Defer zum kann das Rendern beschleunigen, indem der Hauptthread für andere Aufgaben frei wird.
- Bei HTML4-Browsern kann es jedoch zu Verzögerungen kommen.
Verzögerung vs. Platzierung am Ende der Seite
- Mit defer innerhalb von kann ähnliche Ergebnisse erzielen wie das Platzieren von Skripten vor .
- defer garantiert die Ausführungsreihenfolge, während dies bei Skripten, die am Ende des Dokuments platziert werden, nicht der Fall ist.
Verwenden Asynchron mit mehreren Skripten
- Skripte mit Asynchronität können heruntergeladen werden gleichzeitig.
- Aber die Ausführungsreihenfolge ist nicht garantiert, was zu potenziellen Problemen führen kann, wenn Skripte voneinander abhängig sind.
- Stellen Sie sicher, dass Skripte keine Abhängigkeiten aufweisen oder potenzielle Race Conditions verarbeiten.
Aufschieben vs. Asynchron vs. Status Quo
- Aufschieben bewahrt die Ausführung Reihenfolge, wodurch es für die meisten Fälle geeignet ist.
- Async sorgt für etwas schnelleres Laden, birgt jedoch die Möglichkeit einer ungeordneten Ausführung.
- Bis HTML5 weit verbreitet ist, sollten Sie eine Verzögerung der Implementierung in Betracht ziehen, um Kompatibilitätsprobleme zu vermeiden HTML4-Browser.
Das obige ist der detaillierte Inhalt vonAsync vs. Defer: Welches HTML5-Skriptladeattribut optimiert Ihre Website am besten?. 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