Maison >interface Web >js tutoriel >Pourquoi Document.write() supprime-t-il les éléments de formulaire dans les fonctions JavaScript ?
Document.write() et rendu de page
Dans le développement Web, il est rare que la méthode document.write() supprime des éléments de formulaire à partir de l’écran lorsqu’il est invoqué dans une fonction. Cependant, dans des scénarios spécifiques, cela peut effectivement avoir cet effet.
Comprendre document.write()
document.write() est principalement utilisé pour écrire du contenu directement dans le flux de sortie du document HTML. Ce flux est généralement créé lors du premier chargement de la page et fermé lorsque le rendu de la page est terminé.
Étude de cas : Effacement des éléments du formulaire
Dans l'extrait de code fourni, le La méthode document.write() est appelée dans la fonction validator() en réponse à un événement de clic sur le bouton « Appuyez-moi pour validation ». Cet appel est destiné à afficher un message en fonction de l'état de la case à cocher "thebox".
Cependant, le problème se produit car le flux de sortie du document est probablement fermé lorsque la fonction validator() est invoquée. Généralement, ce flux est fermé une fois que la page a fini de charger toutes ses ressources. Lorsque document.write() est appelé sur un flux fermé, il invoque automatiquement document.open(), qui efface l'intégralité du document, y compris tous les éléments du formulaire.
Solution
Pour éviter que les éléments du formulaire ne soient effacés, il est recommandé d'utiliser des méthodes alternatives pour mettre à jour dynamiquement le contenu du document, telles que :
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!