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"}}
"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > 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 ?

Publié le 2024-11-09
Parcourir:243

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

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().

Déclaration de sortie Cet article est réimprimé à l'adresse : 1729404437. En cas d'infraction, veuillez contacter [email protected] pour le supprimer.
Dernier tutoriel Plus>

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