Heim > Web-Frontend > js-Tutorial > Hauptteil

Wie kann der Fehler „Es ist nicht möglich, aus einem asynchron geladenen externen Skript in ein Dokument zu schreiben' behoben werden?

Barbara Streisand
Freigeben: 2024-10-20 14:07:02
Original
936 Leute haben es durchsucht

How to Resolve

Fehler: „Es ist nicht möglich, aus einem asynchron geladenen externen Skript in ein Dokument zu schreiben“

Problem:

Asynchrones Laden von Skripte können zu Problemen führen, wenn versucht wird, ein Dokument mit document.write() zu ändern. Nach der Ausführung des Seitenladevorgangs wird ein Skript asynchron heruntergeladen, schlägt jedoch mit der Konsolenmeldung fehl: „Es ist nicht möglich, aus einem asynchron geladenen externen Skript in ein Dokument zu schreiben, es sei denn, es wird explizit geöffnet.“

Erklärung:

Asynchron geladene Skripte werden ausgeführt, nachdem das Dokument analysiert und geschlossen wurde. Folglich sind Vorgänge wie document.write() in diesen Skripten nicht mehr verfügbar.

Lösung:

Um dieses Problem zu beheben, ersetzen Sie document.write()-Aufrufe durch explizite DOM-Manipulationen. Dazu gehört das Erstellen von DOM-Elementen und deren Einfügen in das übergeordnete Element mithilfe von appendChild(), insertBefore() oder dem Festlegen von innerHTML.

Beispiel:

Originalskript (Inline, mit Dokument. write()):

<code class="html"><div id="container">
<script>
document.write('<span style="color:red;">Hello</span>');
</script>
</div></code>
Nach dem Login kopieren

Geändertes Skript (asynchron geladen, mit DOM-Manipulation):

<code class="javascript">var container = document.getElementById("container");
var content = document.createElement("span");
content.style.color = "red";
content.innerHTML = "Hello";
container.appendChild(content);</code>
Nach dem Login kopieren

Das obige ist der detaillierte Inhalt vonWie kann der Fehler „Es ist nicht möglich, aus einem asynchron geladenen externen Skript in ein Dokument zu schreiben' behoben werden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage
Über uns Haftungsausschluss Sitemap
Chinesische PHP-Website:Online-PHP-Schulung für das Gemeinwohl,Helfen Sie PHP-Lernenden, sich schnell weiterzuentwickeln!