Im JS-Engine-Teil können wir lernen, dass die Rendering-Engine beim Parsen des Skript-Tags die Kontrolle an die JS-Engine übergibt. Wenn das Skript eine externe Ressource lädt, muss es warten, bis es heruntergeladen wird ausgeführt werden. Hier können wir also viel Optimierungsarbeit leisten.
am unteren Rand von BODY
platziertDamit die Rendering-Engine den DOM-Baum so früh wie möglich rendern kann, müssen wir das Skript am unteren Rand des Hauptteils platzieren, damit die Seite so schnell wie möglich aus dem weißen Bildschirm verschwinden kann, d. h. Das DOMContentLoaded-Ereignis wird jedoch frühzeitig ausgelöst, da in iOS Safari, Android Auch wenn Sie das js-Skript am Ende des Körpers in Browser und iOS-Webansicht einfügen, ist das Ergebnis immer noch dasselbe, sodass hier zusätzliche Vorgänge zur Optimierung erforderlich sind Die js-Datei wird geladen.
LADEN VERSCHIEBEN
Dies ist ein in HTML4 definiertes Skriptattribut. Es wird verwendet, um anzugeben, dass das Skript, wenn es auf ein Skript stößt, vorübergehend angehalten und geladen wird. Die Rendering-Engine analysiert weiterhin das folgende HTML-Dokument. Wenn die Analyse abgeschlossen ist, wird das Skript im Skript ausgeführt.
<script src="outside.js" defer></script>
Seine Unterstützung ist <=IE9
Darüber hinaus ist die Ausführungsreihenfolge streng davon abhängig, nämlich:
<script src="outside1.js" defer></script> <script src="outside2.js" defer></script>
Wenn Sie defer unter IE9 verwenden, kann es sein, dass die beiden nicht nacheinander ausgeführt werden. Um damit umzugehen, müssen Sie einen leeren Skript-Tag
zwischen den beiden einfügen.
<script src="outside1.js" defer></script> <script></script> //hack <script src="outside2.js" defer></script>
ASYNC-Laden
async ist ein neu definiertes Skriptattribut in H5. Es ist ein weiterer js-Lademodus.
<script src="outside1.js" async></script> <script src="outside2.js" async></script>
Die Kompatibilität von defer ist relativ schlecht, es handelt sich um IE9, wird aber im Allgemeinen auf mobilen Endgeräten verwendet, sodass dieses Problem nicht besteht.
Skript asynchron
Das asynchrone Skript ist das grundlegende Ladeprinzip, das von einigen asynchronen Ladebibliotheken verwendet wird (z. B. require). Geben Sie den Code direkt ein:
function asyncAdd(src){ var script = document.createElement('script'); script.src = src; document.head.appendChild(script); } //加载js文件 asyncAdd("test.js");
Die auf diese Weise geladenen js-Dateien sind jedoch nicht in Ordnung und abhängige Dateien können nicht normal geladen werden.
Zu diesem Zeitpunkt müssen wir die obige Funktion optimieren.
var asyncAdd = (function(){ var head = document.head, script; return function(src){ script = document.createElement('script'); script.src= src; script.async=false; document.head.appendChild(script); } })(); //加载文件 asyncAdd("first.js"); asyncAdd("second.js"); //或者简便一点 ["first.js","second.js"].forEach((src)=>{async(src);});
Bei Verwendung des statischen asynchronen Ladens werden CSS und JS gleichzeitig geladen
die Wahl zwischen diesen drei betrifft, hängt es hauptsächlich davon ab, welches Ziel uns der Leiter vorgibt , ob es mit IE8, 9, Mobiltelefon, Desktop-Browser oder einer Kombination aus zwei oder zwei kompatibel ist .
Aber für den Fall, dass Sie eine bestimmte Fähigkeit alleine verwenden, müssen Sie bei der Verwendung einige
Tipps beachten.
2. Wenn Sie asynchron verwenden, fügen Sie aus Gründen der Abwärtskompatibilität am Ende „defer“ hinzu
<script src="test.js" async defer></script> //如果两者都支持,async会默认覆盖掉defer //如果只支持一个,则执行对应的即可
Das Obige ist der gesamte Inhalt dieses Artikels. Ich hoffe, er wird für das Studium aller hilfreich sein.