version 1.10, dernière mise à jour le 11 juillet 2005.
XSLT permet de créer, entre autres, des pages HTML
. On peut désirer que ces pages puissent être dotées d'un comportement dynamique ; cela est réalisable via l'insertion de code JavaScript. Mais un certain nombre de précautions doivent être prises afin d'éviter l'interprétation
du code ainsi inséré. Deux approches, à ce niveau, sont possibles. La première consiste à écrire le code JavaScript destiné
à la manipulation du code HTML, ainsi que nous l'avons fait en DHTML
. Le côté "dynamique" est donc déporté sur la gestion du document HTML
créé. La seconde méthode, que nous allons explorer dans ce cours, consiste à incorporer un code JavaScript permettant de
modifier la feuille de style XSL
elle-même. Cette méthode, rendue obsolète par les progrès de la standardisation et de l'accès au DOM par les navigateurs,
est implémentée via une interface propriétaire sous Internet Explorer 6
.
Un code JavaScript, en effet, peut contenir un certain nombre de caractères <
ou >
, qui risquent d'être interprétés par un parser XSL
. Le code doit donc être inséré dans un élément XML
non interprété. Cela donne ainsi l'exemple suivant :
<script type="text/javascript"><![CDATA[(Emplacement du code)]]></script>
Il est alors possible d'écrire le code JavaScript (ou autre...) sans se soucier d'éventuelles incompatibilités de syntaxe.
Avant toute chose, il faut être en mesure de pouvoir lire les fichiers sources XML
et XSL
. Pour cela, on utilise deux collections, document.XMLDocument
et document.XSLDocument
:
var XMLsource = new Object
;
var XSLsource = new Object
;
XMLsource = document.XMLDocument
;
XSLsource = document.XSLDocument
;
Une fois que le fichier XML
est déclaré, il faut pouvoir accéder à ses différents éléments. Cela est réalisé par un appel à la méthode selectNodes()
, qui prend comme argument une expression XPath
, appliquée à la collection documentElement
de l'objet précédemment défini.
XMLsource.documentElement.selectNodes(livre/auteur/@nom)
;
On peut également modifier un élément de la feuille XSL
collection_element=XSLsource.documentElement.selectNodes("xsl:for-each[@select='livre']")
;
element=collection_element[0]
;
element.setAttribute("select", auteur/@nom)
Il est nécessaire, pour terminer, de mettre à jour l'afichage avec les modifications désirées. Cela est réalisé en utilisant
la propriété innerHTML
de l'objet document.body
, et lui affectant le résultat de la transformation de l'objet XML par l'objet XSL modifié :
document.body.innerHTML = XMLsource.transformNode(XSLsource)
;
Consulter l'exemple de tri sur la collection de nuages (source et feuille de style).
Cette création est mise à disposition par Gilles Chagnon sous un contrat Creative Commons.