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!