Maison > interface Web > js tutoriel > Pourquoi document.write() est-il restreint dans les scripts chargés de manière asynchrone ?

Pourquoi document.write() est-il restreint dans les scripts chargés de manière asynchrone ?

Linda Hamilton
Libérer: 2024-10-20 14:09:02
original
630 Les gens l'ont consulté

Why is document.write() Restricted in Asynchronously Loaded Scripts?

Restrictions d'exécution dans les scripts chargés de manière asynchrone : compréhension des limitations de document.write()

Tentative d'écriture dans un document à partir d'un script chargé de manière asynchrone soulève un message de console : "Échec de l'exécution de 'write' sur 'Document' : il n'est pas possible d'écrire dans un document à partir d'un script externe chargé de manière asynchrone à moins qu'il ne soit explicitement ouvert." Ce message peut apparaître malgré le comportement attendu du script, laissant les développeurs perplexes.

Pourquoi la restriction existe

Les scripts chargés de manière asynchrone s'exécutent souvent après que le document a été analysé et fermé. Par conséquent, utiliser document.write() à partir de tels scripts devient problématique car le document n'est plus ouvert en écriture.

Solution : Manipulation explicite du DOM

Au lieu d'utiliser document.write() .write(), les développeurs doivent manipuler explicitement le DOM dans des scripts chargés de manière asynchrone. Cela implique de créer des éléments DOM et de les insérer dans l'élément parent souhaité à l'aide de méthodes telles que .appendChild(), .insertBefore() ou la définition de .innerHTML.

Exemple : Manipulation DOM

Pour illustrer, considérons le script en ligne suivant :

<div id="container">
<script>
  document.write('<span style="color:red;">Hello</span>');
</script>
</div>
Copier après la connexion

Dans un script chargé de manière asynchrone, ce code pourrait être remplacé par :

var container = document.getElementById("container");
var content = document.createElement("span");
content.style.color = "red";
content.innerHTML = "Hello";
container.appendChild(content);
Copier après la connexion

Alternativement, puisque le conteneur est vide, le code simplifié suivant pourrait être utilisé :

var container = document.getElementById("container");
container.innerHTML = '<span style="color:red;">Hello</span>';
Copier après la connexion

En adoptant ces techniques de manipulation DOM, les développeurs peuvent écrire efficacement dans des documents à partir de scripts chargés de manière asynchrone, évitant ainsi les limitations imposées par document.write().

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Derniers articles par auteur
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal