Maison > interface Web > js tutoriel > Comment contourner les limitations de document.write() lors du chargement de scripts asynchrones ?

Comment contourner les limitations de document.write() lors du chargement de scripts asynchrones ?

Patricia Arquette
Libérer: 2024-10-20 14:04:02
original
532 Les gens l'ont consulté

How to Override document.write() Limitations in Asynchronous Script Loading?

Chargement de scripts asynchrones : comprendre les limitations de document.write()

Lors de l'exécution de scripts de manière asynchrone, après le chargement initial de la page, il est essentiel d'être conscient des limites que cela pose à la manipulation de documents. Comme indiqué dans le message de la console : "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."

Cela signifie que l'utilisation de document.write() dans un tel script externe les scripts chargés n'écriveront pas efficacement dans le document, même si le script lui-même se charge correctement. La raison réside dans le fait que les scripts asynchrones s'exécutent après l'analyse et la fermeture du document.

Pour résoudre ce problème, il est nécessaire de remplacer document.write() par des manipulations explicites du DOM. Au lieu d'écrire directement dans le document, créez les éléments DOM souhaités et ajoutez-les au document à l'aide de méthodes telles que appendChild(), insertBefore() ou en définissant la propriété innerHTML.

Par exemple, au lieu d'utiliser document .write() dans un script en ligne :

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

Dans un script chargé dynamiquement, remplacez-le par ce qui suit :

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, s'il n'y a aucun autre contenu dans le conteneur , vous pouvez définir directement la propriété innerHTML :

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

En suivant ces directives, vous pouvez manipuler efficacement le DOM à partir de scripts chargés de manière asynchrone sans rencontrer l'erreur « Échec de l'exécution de 'write' sur 'Document' ».

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