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 = \\'Hello\\';
En adoptant ces techniques de manipulation du DOM, les développeurs peuvent écrire efficacement dans des documents à partir de scripts chargés de manière asynchrone, évitant ainsi les limitations imposé par document.write().
","image":"http://www.luping.net/uploads/20241104/17307187276728ac0702fe7.jpg","datePublished":"2024-11-09T03:16:22+08:00","dateModified":"2024-11-09T03:16:22+08:00","author":{"@type":"Person","name":"luping.net","url":"https://www.luping.net/articlelist/0_1.html"}}Restrictions d'exécution dans les scripts chargés de manière asynchrone : comprendre les limitations de document.write()
Tenter d'écrire 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 le document .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 en définissant .innerHTML.
Exemple : Manipulation DOM
Pour illustrer, considérons le script en ligne suivant :
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 = 'Hello';
En adoptant ces techniques de manipulation du DOM, les développeurs peuvent écrire efficacement dans des documents à partir de scripts chargés de manière asynchrone, évitant ainsi les limitations imposé par document.write().
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3