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
Linda Hamiltonoriginal
2024-10-20 14:09:02634parcourir

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>

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);

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>';

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!

Déclaration:
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