Heim >Web-Frontend >js-Tutorial >Warum ist document.write() in asynchron geladenen Skripten eingeschränkt?
Ausführungseinschränkungen in asynchron geladenen Skripten: Grundlegendes zu den Einschränkungen von document.write()
Der Versuch, aus einem asynchron geladenen Skript in ein Dokument zu schreiben, löst einen Fehler aus eine Konsolenmeldung: „Fehler beim Ausführen von ‚Schreiben‘ für ‚Dokument‘: Es ist nicht möglich, aus einem asynchron geladenen externen Skript in ein Dokument zu schreiben, es sei denn, es wird explizit geöffnet.“ Diese Meldung kann trotz des erwarteten Verhaltens des Skripts erscheinen und Entwickler verwirren.
Warum die Einschränkung besteht
Asynchron geladene Skripte werden oft ausgeführt, nachdem das Dokument analysiert wurde und geschlossen. Folglich wird die Verwendung von document.write() aus solchen Skripten problematisch, da das Dokument nicht mehr zum Schreiben geöffnet ist.
Lösung: Explizite DOM-Manipulation
Anstelle der Verwendung von document .write() müssen Entwickler das DOM in asynchron geladenen Skripten explizit manipulieren. Dazu müssen DOM-Elemente erstellt und mithilfe von Methoden wie .appendChild(), .insertBefore() oder der Einstellung .innerHTML in das gewünschte übergeordnete Element eingefügt werden.
Beispiel: DOM-Manipulation
Betrachten Sie zur Veranschaulichung das folgende Inline-Skript:
<div id="container"> <script> document.write('<span style="color:red;">Hello</span>'); </script> </div>
In einem asynchron geladenen Skript könnte dieser Code ersetzt werden durch:
var container = document.getElementById("container"); var content = document.createElement("span"); content.style.color = "red"; content.innerHTML = "Hello"; container.appendChild(content);
Alternativ, da der Container ist leer, könnte der folgende vereinfachte Code verwendet werden:
var container = document.getElementById("container"); container.innerHTML = '<span style="color:red;">Hello</span>';
Durch die Übernahme dieser DOM-Manipulationstechniken können Entwickler effektiv aus asynchron geladenen Skripten in Dokumente schreiben und dabei die durch document.write() auferlegten Einschränkungen vermeiden.
Das obige ist der detaillierte Inhalt vonWarum ist document.write() in asynchron geladenen Skripten eingeschränkt?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!