Wenn eine Webseite geladen wird, durchläuft der Browser eine Reihe von Schritten, um die Seite zu verarbeiten und darzustellen. Im Folgenden finden Sie eine vereinfachte Übersicht über diesen Prozess:
Der Browser lädt das HTML-Dokument herunter und beginnt mit der Analyse. Dazu gehört die Tokenisierung des HTML-Codes, die Erstellung eines DOM-Baums und die Prüfung auf Syntaxfehler.
Während das HTML analysiert wird, identifiziert und lädt der Browser auch alle externen CSS-Dateien. Diese CSS-Dateien werden in eine Reihe von Stilregeln analysiert, die dann auf das DOM angewendet werden.
Externe JavaScript-Dateien werden heruntergeladen und in der Reihenfolge ausgeführt, in der sie im HTML erscheinen. Inline-JavaScript wird so ausgeführt, wie es beim HTML-Parsing auftritt.
Andere Ressourcen wie Bilder, Schriftarten und Mediendateien werden parallel heruntergeladen und für die zukünftige Verwendung zwischengespeichert.
Nachdem alle externen Ressourcen geladen wurden, erstellt der Browser den endgültigen DOM-Baum und wendet die CSS-Stile an. Ereignis-Listener sind an HTML-Elemente gebunden, sodass Benutzer mit der Seite interagieren können.
In Ihrem Beispiel ersetzt kkk.png abc.jpg als Quelle für das Bild durch die ID „img“. Dies liegt daran, dass der Code in $(document).ready() ausgeführt wird, nachdem alle externen Ressourcen geladen wurden und das DOM bereit ist.
Das ersetzte Bild wird heruntergeladen und auf der Seite gerendert.
Während die allgemeine Lade- und Ausführungssequenz bei allen Browsern gleich ist, kann es zu geringfügigen Abweichungen kommen Variationen in der Umsetzung. Einige Browser geben beispielsweise möglicherweise der CSS-Analyse Vorrang vor der JavaScript-Ausführung oder implementieren Optimierungen wie das verzögerte Laden von Bildern.
Während das Laden von CSS und Ressourcen parallel erfolgen kann, erfolgt die Ausführung von JavaScript folgt einem Single-Threaded-Modell. Das bedeutet, dass der Browser JavaScript-Code Anweisung für Anweisung ausführt und die Ausführung externer Skripte das Parsen des HTML-Dokuments blockiert.
Das obige ist der detaillierte Inhalt vonWie lädt und führt ein Webbrowser eine Webseite aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!