JavaScript : l'objet Document
Grâce à ses propriétés et méthodes l'objet JavaScript Document influe sur le contenu réel de la page; il est la page.
Comme nous l'avons vu pour l'objet Window, l'accès aux propriétés et méthodes de l'objet se fait de la manière suivante:
[window.]document.nom_propriété
[window.]document.nom_méthode ([paramètres])
Propriétés et méthodes
Exemples JavaScript pour l'objet Document
document.write()
C'est par cette méthode que nous pouvons créer le contenu de la page, soit au chargement de celle-ci, soit ultérieurement (script différé), afin d'en modifier le contenu ou l'apparence. Le script différé permet la création du contenu dans une autre fenêtre ou dans la fenêtre courante.
Au moment où une page est chargée, le flux de sortie du navigateur est fermé. La méthode document.write() ouvre un nouveau flux, la page courante est donc automatiquement effacée, ainsi que toutes les variables qu'elle contenait. Afin de remplacer la page courante par du code HTML, il suffit d'affecter ces données à une variable qui sera appelée par la méthode.
Le premier exemple permet de modifier l'ensemble du contenu HTML du document dans une même fenêtre.
<script type="text/javascript"> //<![CDATA[ function ecrit_dans_fenetre(){ var nouveau_contenu = "<html><head>"; nouveau_contenu += "<title>Même fenêtre, autre contenu.</title>"; nouveau_contenu += "</head><body>"; nouveau_contenu += "<h1>Résultat du script :</h1>"; nouveau_contenu += "<p>La fen&ecirc;tre n'a pas chang&eacute;. Seul le contenu du document est modifi&eacute;.</p>"; nouveau_contenu += "<p>Cliquons maintenant sur retour pour revenir au pr&eacute;c&eacute;dent contenu.</p>"; nouveau_contenu += " <form><input type=\"button\" value=\"retour\" onClick=\"window.history.back();\" /></form>"; nouveau_contenu += "</body></html>"; document.write(nouveau_contenu); document.close(); } //]]> </script>
Le deuxième exemple permet l'ouverture d'une nouvelle fenêtreavec la définition de son contenu HTML :
<script type="text/javascript"> //<![CDATA[ var nouvelle_fenetre; function cree_nouvelle_fenetre(){ nouvelle_fenetre = window.open("","","status='test', height=250, width=400"); } function ecrit(){ //créer la fenêtre si elle n'existe pas, ou si elle a été fermée if (!nouvelle_fenetre || nouvelle_fenetre.closed) { cree_nouvelle_fenetre(); } //faire passer cette fenêtre au premier plan nouvelle_fenetre.focus(); //définition du contenu var nouveau_contenu = "<html><head><title>Autre fenêtre, autre contenu</title><link rel=\"stylesheet\" href=\"mapage.html\"></head>"; nouveau_contenu += "<body> <h1>Résultat du script:</h1><br><br><p>C'est donc pour cette nouvelle fenêtre que nous avons défini ce contenu HTML.</p></body></html>"; //écriture nouvelle_fenetre.document.write(nouveau_contenu); nouvelle_fenetre.document.close(); } //]]> </script>
Note
Dans le code du deuxième exemple :
- La variable nouvelle_fenetre (nouvelle fenêtre) est déclarée comme variable globale, afin que les différentes fonctions du script puissent l'utiliser.
- Les doubles slashes (//) permettent les commentaires, comme en langage C.
- Pour la nouvelle fenêtre, la largeur et la hauteur sont spécifiées, ainsi que la présence de la barre de statut.
- Une structure de contrôle permet de vérifier que la fenêtre soit bien fermée avant de l'ouvrir.
- Dans la structure de contrôle, le double pipe (||) correspond à un ou logique.
- Le focus est donné à la nouvelle fenêtre (ce qui n'est pas indispensable dans ce cas, mais nous permet de découvrir certaines possibilités) afin de la situer au premier plan dans le cas ou le visiteur impatient aurait déjà cliqué par exemple sur la page principale.
- Les méthodes document.write() et document.close() spécifient maintenant la fenêtre concernée (nouvelle_fenetre).
English translation
You have asked to visit this site in English. For now, only the interface is translated, but not all the content yet.If you want to help me in translations, your contribution is welcome. All you need to do is register on the site, and send me a message asking me to add you to the group of translators, which will give you the opportunity to translate the pages you want. A link at the bottom of each translated page indicates that you are the translator, and has a link to your profile.
Thank you in advance.
Document created the 19/03/2002, last modified the 04/11/2018
Source of the printed document:https://www.gaudry.be/en/javascript-window-document.html
The infobrol is a personal site whose content is my sole responsibility. The text is available under CreativeCommons license (BY-NC-SA). More info on the terms of use and the author.