From 1407c8fdef01ecd0ffb8a8bd46e7113f119b9fde Mon Sep 17 00:00:00 2001 From: julieng Date: Sat, 2 Oct 2021 17:20:24 +0200 Subject: convert content to md --- .../web/api/xsltprocessor/basic_example/index.md | 83 +++---- .../api/xsltprocessor/browser_differences/index.md | 24 +- .../web/api/xsltprocessor/generating_html/index.md | 267 ++++++++++----------- files/fr/web/api/xsltprocessor/index.md | 201 ++++++---------- .../xsl_transformations_in_mozilla_faq/index.md | 85 ++++--- 5 files changed, 303 insertions(+), 357 deletions(-) (limited to 'files/fr/web/api/xsltprocessor') diff --git a/files/fr/web/api/xsltprocessor/basic_example/index.md b/files/fr/web/api/xsltprocessor/basic_example/index.md index fb6884c046..f7de3132b2 100644 --- a/files/fr/web/api/xsltprocessor/basic_example/index.md +++ b/files/fr/web/api/xsltprocessor/basic_example/index.md @@ -4,63 +4,58 @@ slug: Web/API/XSLTProcessor/Basic_Example translation_of: Web/API/XSLTProcessor/Basic_Example original_slug: XSLT_dans_Gecko/Exemple_basique --- -

    -
  1. Introduction
  2. -
  3. Exemple basique
  4. -
  5. Génération de HTML
  6. -
  7. Différences entre les navigateurs
  8. -
  9. Ressources
  10. -

+1. [Introduction](/fr/docs/XSLT_dans_Gecko) +2. [Exemple basique](/fr/docs/XSLT_dans_Gecko/Exemple_basique) +3. [Génération de HTML](/fr/docs/XSLT_dans_Gecko/G%c3%a9n%c3%a9ration_de_HTML) +4. [Différences entre les navigateurs](/fr/docs/XSLT_dans_Gecko/Diff%c3%a9rences_entre_les_navigateurs) +5. [Ressources](/fr/docs/XSLT_dans_Gecko/Ressources) -

Exemple basique

+## Exemple basique -

Ce premier exemple présente les bases de l'utilisation d'une transformation XSLT dans un navigateur. L'exemple utilise un document XML qui contient des informations (titre, liste d'auteurs et corps de texte) à propos d'un article pour en tirer une version lisible par un humain.

+Ce premier exemple présente les bases de l'utilisation d'une transformation XSLT dans un navigateur. L'exemple utilise un document XML qui contient des informations (titre, liste d'auteurs et corps de texte) à propos d'un article pour en tirer une version lisible par un humain. -

La figure 1 montre le code source de l'exemple XSLT. Le document XML (exemple.xml) contient les informations à propos de l'article. En utilisant l'instruction de traitement ?xml-stylesheet?, il est lié à la feuille de style XSLT (exemple.xsl) via son attribut href.

+La figure 1 montre le code source de l'exemple XSLT. Le document XML (exemple.xml) contient les informations à propos de l'article. En utilisant l'instruction de traitement `?xml-stylesheet?`, il est lié à la feuille de style XSLT (exemple.xsl) via son attribut `href`. -

Une feuille de style XSLT débute par l'élément xsl:stylesheet, qui contient tous les modèles utilisés pour créer le résultat final. L'exemple de la figure 1 possède deux modèles - un qui s'applique au nœud racine et un aux nœuds Author. Le modèle correspondant au nœud racine produit en sortie le titre de l'article puis déclenche le traitement de tous les autres modèles (via apply-templates) correspondant aux nœuds Author qui sont les descendants du nœud Authors.

+Une feuille de style XSLT débute par l'élément `xsl:stylesheet`, qui contient tous les modèles utilisés pour créer le résultat final. L'exemple de la figure 1 possède deux modèles - un qui s'applique au nœud racine et un aux nœuds `Author`. Le modèle correspondant au nœud racine produit en sortie le titre de l'article puis déclenche le traitement de tous les autres modèles (via `apply-templates`) correspondant aux nœuds `Author` qui sont les descendants du nœud `Authors`. -

Figure 1 : exemple XSLT simple

+Figure 1 : exemple XSLT simple -

Document XML (exemple.xml) :

+Document XML (exemple.xml) : -
  <?xml version="1.0"?>
-  <?xml-stylesheet type="text/xsl" href="exemple.xsl"?>
-  <Article>
-    <Title>Mon article</Title>
-    <Authors>
-      <Author>M. Foo</Author>
-      <Author>M. Bar</Author>
-    </Authors>
-    <Body>Ceci est le texte de mon article.</Body>
-  </Article>
-
+ + +
+ Mon article + + M. Foo + M. Bar + + Ceci est le texte de mon article. +
-

Feuille de style XSL (exemple.xsl) :

+Feuille de style XSL (exemple.xsl) : -
  <?xml version="1.0"?>
-  <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
+      
+      
 
-    <xsl:output method="text"/>
+        
 
-    <xsl:template match="/">
-      Article - <xsl:value-of select="/Article/Title"/>
-      Auteurs : <xsl:apply-templates select="/Article/Authors/Author"/>
-    </xsl:template>
+        
+          Article - 
+          Auteurs : 
+        
 
-    <xsl:template match="Author">
-      - <xsl:value-of select="." />
-    </xsl:template>
+        
+          - 
+        
 
-  </xsl:stylesheet>
-
+ -

Sortie dans le navigateur :

+Sortie dans le navigateur : -
  Article - Mon article
-  Auteurs :
-  - M. Foo
-  - M. Bar
-
+ Article - Mon article + Auteurs : + - M. Foo + - M. Bar -

{{PreviousNext("XSLT dans Gecko", "XSLT dans Gecko:Génération de HTML")}}

+{{PreviousNext("XSLT dans Gecko", "XSLT dans Gecko:Génération de HTML")}} diff --git a/files/fr/web/api/xsltprocessor/browser_differences/index.md b/files/fr/web/api/xsltprocessor/browser_differences/index.md index 5ab86ed667..a8cb10124a 100644 --- a/files/fr/web/api/xsltprocessor/browser_differences/index.md +++ b/files/fr/web/api/xsltprocessor/browser_differences/index.md @@ -4,20 +4,16 @@ slug: Web/API/XSLTProcessor/Browser_Differences translation_of: Web/API/XSLTProcessor/Browser_Differences original_slug: XSLT_dans_Gecko/Différences_entre_les_navigateurs --- -

    -
  1. Introduction
  2. -
  3. Exemple basique
  4. -
  5. Génération de HTML
  6. -
  7. Différences entre les navigateurs
  8. -
  9. Ressources
  10. -

+1. [Introduction](/fr/docs/XSLT_dans_Gecko) +2. [Exemple basique](/fr/docs/XSLT_dans_Gecko/Exemple_basique) +3. [Génération de HTML](/fr/docs/XSLT_dans_Gecko/G%c3%a9n%c3%a9ration_de_HTML) +4. [Différences entre les navigateurs](/fr/docs/XSLT_dans_Gecko/Diff%c3%a9rences_entre_les_navigateurs) +5. [Ressources](/fr/docs/XSLT_dans_Gecko/Ressources) -

Différences entre les navigateurs

+## Différences entre les navigateurs - +- Netscape 7.x (toutes plateformes confondues) et Internet Explorer 6 (Windows) support ent la recommandation [XSLT 1.0 (en)](http://www.w3.org/TR/xslt) du W3C. +- IE 5.0 et 5.5 (Windows) ne supportent que le brouillon de travail de XSLT, et ne sont donc pas compatibles avec les feuilles de style XSLT 1.0. +- Netscape 6.x ne supporte que partiellement XSLT 1.0. -

{{PreviousNext("XSLT dans Gecko:Génération de HTML", "XSLT dans Gecko:Ressources")}}

+{{PreviousNext("XSLT dans Gecko:Génération de HTML", "XSLT dans Gecko:Ressources")}} diff --git a/files/fr/web/api/xsltprocessor/generating_html/index.md b/files/fr/web/api/xsltprocessor/generating_html/index.md index 59286d20d5..535ee31fe5 100644 --- a/files/fr/web/api/xsltprocessor/generating_html/index.md +++ b/files/fr/web/api/xsltprocessor/generating_html/index.md @@ -4,188 +4,181 @@ slug: Web/API/XSLTProcessor/Generating_HTML translation_of: Web/API/XSLTProcessor/Generating_HTML original_slug: XSLT_dans_Gecko/Génération_de_HTML --- -

    -
  1. Introduction
  2. -
  3. Exemple basique
  4. -
  5. Génération de HTML
  6. -
  7. Différences entre les navigateurs
  8. -
  9. Ressources
  10. -

+1. [Introduction](/fr/docs/XSLT_dans_Gecko) +2. [Exemple basique](/fr/docs/XSLT_dans_Gecko/Exemple_basique) +3. [Génération de HTML](/fr/docs/XSLT_dans_Gecko/G%c3%a9n%c3%a9ration_de_HTML) +4. [Différences entre les navigateurs](/fr/docs/XSLT_dans_Gecko/Diff%c3%a9rences_entre_les_navigateurs) +5. [Ressources](/fr/docs/XSLT_dans_Gecko/Ressources) -

Génération de HTML

+## Génération de HTML -

Une application courante de XSLT dans les navigateurs est la transformation de code XML en HTML du coté du client. Le second exemple va transformer un document d'entrée (example2.xml), qui contient des informations à propos d'un article, en un document HTML.

+Une application courante de XSLT dans les navigateurs est la transformation de code XML en HTML du coté du client. Le second exemple va transformer un document d'entrée (example2.xml), qui contient des informations à propos d'un article, en un document HTML. -

L'élément <body> de l'article contient maintenant des éléments HTML (des balises <strong> et <em>, voir la figure 2). Le document XML contient à la fois des éléments HTML et éléments XML, mais un seul espace de nommage est nécessaire, pour les éléments XML. Comme il n'existe pas d'espace de nommage HTML, et que l'utilisation de l'espace de nommage XHTML forcerait le XSL à créer un document XML qui pourrait ne pas se comporter comme un document HTML, le nœud xsl:output de la feuille de style assure que le document résultant sera bien traité comme du HTML. Pour les éléments XML, nous avons besoin de notre propre espace de nommage, http://devedge.netscape.com/2002/de, à qui nous donnons le préfixe myNS (xmlns:myNS="http://devedge.netscape.com/2002/de").

+L'élément `` de l'article contient maintenant des éléments HTML (des balises `` et ``, voir la figure 2). Le document XML contient à la fois des éléments HTML et éléments XML, mais un seul espace de nommage est nécessaire, pour les éléments XML. Comme il n'existe pas d'espace de nommage HTML, et que l'utilisation de l'espace de nommage XHTML forcerait le XSL à créer un document XML qui pourrait ne pas se comporter comme un document HTML, le nœud `xsl:output` de la feuille de style assure que le document résultant sera bien traité comme du HTML. Pour les éléments XML, nous avons besoin de notre propre espace de nommage, [`http://devedge.netscape.com/2002/de`](http://devedge.netscape.com/2002/de), à qui nous donnons le préfixe myNS `(xmlns:myNS="http://devedge.netscape.com/2002/de")`. -

Figure 2 : fichier XML (example2.xml)voir l'exemple | voir le source Document XML (example2.xml): <div style="background: #EEE; font-size: 1.1em; line-height: 1.1em; border: dashed #666 1px; padding: 15px 20px 15px 20px; overflow: auto;">

+**Figure 2 : fichier XML (example2.xml)voir l'exemple | voir le source** Document XML (example2.xml): \
-
<?xml version="1.0"?>
-<?xml-stylesheet type="text/xsl" href="example.xsl"?>
-  <myNS:Article xmlns:myNS="http://devedge.netscape.com/2002/de">
-    <myNS:Title>Mon article</myNS:Title>
-    <myNS:Authors>
-      <myNS:Author company="Foopy Corp.">M. Foo</myNS:Author>
-      <myNS:Author>M. Bar</myNS:Author>
-    </myNS:Authors>
-    <myNS:Body>
-      En <em>Espagne</em>, les <strong>pluies</strong> se concentrent
-      principalement dans les plaines.
-    </myNS:Body>
-  </myNS:Article>
-
+ + + + Mon article + + M. Foo + M. Bar + + + En Espagne, les pluies se concentrent + principalement dans les plaines. + + -

La feuille de style XSL utilisée aura besoin de deux espaces de nommage - un pour les éléments XSLT et un pour nos propres éléments XML utilisés dans le document XML. La sortie de la feuille de style XSL est définie à HTML à l'aide de l'élément xsl:output. En définissant la sortie comme étant du code HTML et en n'ayant pas d'espace de nommage pour les éléments résultants (coloré en bleu), ces éléments seront traités comme des éléments HTML.

+La feuille de style XSL utilisée aura besoin de deux espaces de nommage - un pour les éléments XSLT et un pour nos propres éléments XML utilisés dans le document XML. La sortie de la feuille de style XSL est définie à `HTML` à l'aide de l'élément `xsl:output`. En définissant la sortie comme étant du code HTML et en n'ayant pas d'espace de nommage pour les éléments résultants (coloré en bleu), ces éléments seront traités comme des éléments HTML. -

Figure 3 : feuille de style XSL avec 2 espaces de nommage (example2.xsl) feuille de style XSL (example2.xsl):

+**Figure 3 : feuille de style XSL avec 2 espaces de nommage** (example2.xsl) feuille de style XSL (example2.xsl): -
  <?xml version="1.0"?>
-  <xsl:stylesheet version="1.0"
-                           xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-                           xmlns:myNS="http://devedge.netscape.com/2002/de">
+      
+      
 
-    <xsl:output method="html"/>
-    ...
-  </xsl:stylesheet>
-
+ + ... + -

Un modèle s'appliquant au nœud racine du document XML est créé et utilisé pour créer la structure de base de la page HTML.

+Un modèle s'appliquant au nœud racine du document XML est créé et utilisé pour créer la structure de base de la page HTML. -

Figure 4 : Création du document HTML de base feuille de style XSL (example2.xsl):

+**Figure 4 : Création du document HTML de base** feuille de style XSL (example2.xsl): -
  ...
-  <xsl:template match="/">
-  <html>
+      ...
+      
+      
 
-    <head>
+        
 
-      <title>
-        <xsl:value-of select="/myNS:Article/myNS:Title"/>
-      </title>
+          
+            <xsl:value-of select="/myNS:Article/myNS:Title"/>
+          
 
-      <style type="text/css">
-        .myBox {margin:10px 155px 0 50px; border: 1px dotted #639ACE; padding:0 5px 0 5px;}
-      </style>
+          
 
-    </head>
+        
 
-    <body>
-      <p class="myBox">
-        <span class="title">
-          <xsl:value-of select="/myNS:Article/myNS:Title"/>
-        </span> <br />
+        
+          

+ + +
- Auteurs : <br /> - <xsl:apply-templates select="/myNS:Article/myNS:Authors/myNS:Author"/> - </p> + Auteurs :
+ +

- <p class="myBox"> - <xsl:apply-templates select="//myNS:Body"/> - </p> +

+ +

- </body> + - </html> - </xsl:template> - ... -
+ + + ... -

Nous avons besoin de trois xsl:template supplémentaires pour parachever l'exemple. Le premier xsl:template est utilisé pour les nœuds Author, alors que le deuxième traite le nœud body. Le troisième possède une règle de correspondance générale qui lui permet de s'appliquer à chaque nœud et chaque attribut. Cela est nécessaire afin de préserver les éléments HTML présents dans le document XML : il s'appliquant à tous, et les recopie dans le document HTML créé par la transformation.

+Nous avons besoin de trois `xsl:template` supplémentaires pour parachever l'exemple. Le premier `xsl:template` est utilisé pour les nœuds `Author`, alors que le deuxième traite le nœud `body`. Le troisième possède une règle de correspondance générale qui lui permet de s'appliquer à chaque nœud et chaque attribut. Cela est nécessaire afin de préserver les éléments HTML présents dans le document XML : il s'appliquant à tous, et les recopie dans le document HTML créé par la transformation. -

Figure 5 : Les 3 modèles finaux feuille de style XSL (example2.xsl):

+**Figure 5 : Les 3 modèles finaux** feuille de style XSL (example2.xsl): -
  ...
-  <xsl:template match="myNS:Author">
-     --   <xsl:value-of select="." />
+      ...
+      
+         --   
 
-    <xsl:if test="@company">
-     ::   <strong>  <xsl:value-of select="@company" />  </strong>
-    </xsl:if>
+        
+         ::       
+        
 
-    <br />
-  </xsl:template>
+        
+
- <xsl:template match="myNS:Body"> - <xsl:copy> - <xsl:apply-templates select="@*|node()"/> - </xsl:copy> - </xsl:template> + + + + + - <xsl:template match="@*|node()"> - <xsl:copy> - <xsl:apply-templates select="@*|node()"/> - </xsl:copy> - </xsl:template> - ... -
+ + + + + + ... -

La feuille de style XSLT finale est donc :

+La feuille de style XSLT finale est donc : -

Figure 6 : feuille de style XSLT finale voir l'exemple | voir le source feuille de style XSL :

+**Figure 6 : feuille de style XSLT finale voir l'exemple | voir le source** feuille de style XSL : -
  <?xml version="1.0"?>
-  <xsl:stylesheet version="1.0"
-                           xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
-                           xmlns:myNS="http://devedge.netscape.com/2002/de">
+      
+      
 
-    <xsl:output method="html" />
+        
 
-    <xsl:template match="/">
-      <html>
+        
+          
 
-        <head>
+            
 
-          <title>
-            <xsl:value-of select="/myNS:Article/myNS:Title"/>
-          </title>
+              
+                <xsl:value-of select="/myNS:Article/myNS:Title"/>
+              
 
-          <style type="text/css">
-            .myBox {margin:10px 155px 0 50px; border: 1px dotted #639ACE; padding:0 5px 0 5px;}
-          </style>
+              
 
-        </head>
+            
 
-        <body>
-          <p class="myBox">
-            <span class="title">
-              <xsl:value-of select="/myNS:Article/myNS:Title"/>
-            </span> <br />
+            
+              

+ + +
- Authors: <br /> - <xsl:apply-templates select="/myNS:Article/myNS:Authors/myNS:Author"/> - </p> + Authors:
+ +

- <p class="myBox"> - <xsl:apply-templates select="//myNS:Body"/> - </p> +

+ +

- </body> + - </html> - </xsl:template> + +
- <xsl:template match="myNS:Author"> - -- <xsl:value-of select="." /> + + -- - <xsl:if test="@company"> -  :: <b> <xsl:value-of select="@company" /> </b> - </xsl:if> + +  :: + - <br /> - </xsl:template> +
+
- <xsl:template match="myNS:Body"> - <xsl:copy> - <xsl:apply-templates select="@*|node()"/> - </xsl:copy> - </xsl:template> + + + + + - <xsl:template match="@*|node()"> - <xsl:copy> - <xsl:apply-templates select="@*|node()"/> - </xsl:copy> - </xsl:template> - </xsl:stylesheet> -
+ + + + + + -

{{PreviousNext("XSLT dans Gecko:Exemple basique", "XSLT dans Gecko:Différences entre les navigateurs")}}

+{{PreviousNext("XSLT dans Gecko:Exemple basique", "XSLT dans Gecko:Différences entre les navigateurs")}} diff --git a/files/fr/web/api/xsltprocessor/index.md b/files/fr/web/api/xsltprocessor/index.md index 68179a3bce..27da398efa 100644 --- a/files/fr/web/api/xsltprocessor/index.md +++ b/files/fr/web/api/xsltprocessor/index.md @@ -10,126 +10,81 @@ tags: - XSLT translation_of: Web/API/XSLTProcessor --- -
{{APIRef("XSLT")}}
- -

Un XSLTProcessor applique une transformation de feuille de style XSLT à un document XML pour générer un nouveau document XML. Il fait appel à des méthodes pour charger la feuille de style XSLT, donner des valeurs aux paramètres <xsl:param> et pour appliquer les transformations au document.

- -

Syntaxe

- -

Le constructeur n'a pas de paramètre.

- -
new XSLTProcessor()
- -

Méthodes

- -
-
[Throws] void {{domxref("XSLTProcessor.importStylesheet")}}({{domxref("Node")}} styleSheet)
-
Importe une feuille de style XSLT. Si le nœud passé en argument est un nœud de document, vous pouvez passer une transformation XSL complète ou un transformation d'élèment résultant; sinon, il doit s'agir d'un élèment <xsl:stylesheet> ou <xsl:transform>.
-
[Throws] {{domxref("DocumentFragment")}} {{domxref("XSLTProcessor.transformToFragment")}}({{domxref("Node")}} source, {{domxref("Document")}} owner)
-
Transforme la source du nœud en applicant la fonction {{domxref("XSLTProcessor.importStylesheet()")}}. Le document propriétaire du fragment de document résultant est le nœud propriétaire.
-
[Throws] {{domxref("Document")}} {{domxref("XSLTProcessor.transformToDocument")}}({{domxref("Node")}} source)
-
-

Transforme la source du nœud en appliquant la feuille de style donnée lors de l'importation à l'aide de la fonction {{domxref ("XSLTProcessor.importStylesheet ()")}}.

- -

L'objet résultant dépend de la méthode de sortie de la feuille de style :

- - - - - - - - - - - - - - - - - - - - - - -
Méthode de sortieType de résultat
html{{domxref("HTMLDocument")}}
xml{{domxref("XMLDocument")}}
text{{domxref("XMLDocument")}} avec un seul élèment racine <transformiix:result> avec le texte comme enfant
-
-
[Throws] void {{domxref("XSLTProcessor.setParameter")}}({{jsxref("String")}} namespaceURI, {{jsxref("String")}} localName, any value)
-
Définit un paramètre dans la feuille de style XSLT qui a été importée. (Définit la valeur d'un <xsl:param>.) Une valeur nulle pour namespaceURI sera traitée comme une chaîne vide.
-
[Throws] any {{domxref("XSLTProcessor.getParameter")}}({{jsxref("String")}} namespaceURI, {{jsxref("String")}} localName)
-
Récupére un paramètre de la feuille de style XSLT. Une valeur nulle pour namespaceURI sera traitée comme une chaîne vide.
-
[Throws] void {{domxref("XSLTProcessor.removeParameter")}}({{jsxref("String")}} namespaceURI, {{jsxref("String")}} localName)
-
Supprime le paramètre s'il a déjà été défni. Le XSLTProcessor utilisera alors la valeur par défaut du paramètre. Si une valeur nulle est donnée pour namespaceURI, elle sera traitée comme une chaîne vide.
-
void {{domxref("XSLTProcessor.clearParameters()")}}
-
Supprime tous les paramètres définis dans le XSLTProcessor. Le XSLTProcessor utilisera alors les valeurs par défaut spécifiées dans la feuille de style XSLT.
-
void {{domxref("XSLTProcessor.reset()")}}
-
Supprime tous les paramétres et feuilles de style du XSLTProcessor.
-
- -

Propriétés

- -

Propriétés non-apparentes au Web

- -

Les propriétés suivantes sont [ChromeOnly] et ne sont pas apparentes au contenu Web :

- -
-
[ChromeOnly] attribute unsigned long {{domxref("XSLTProcessor.flags")}}
-
-

Drapeaux qui modifient le comportement du processeur. Pas de réinitialisation en appelant {{domxref("XSLTProcessor.reset()")}}. Valeur par défaut: 0

- -

Possible values are:

- - - - - - - - - - - - - - - - - - - - - -
NomValeurEffet
(None)0Aucun
DISABLE_ALL_LOADS1Désactiver le chargement de documents externes (par ex. <xsl:import> et document())
-
-
- -

Exemples

- -
    -
  1. Exemple simple
  2. -
  3. Exemple avancé
  4. -
  5. Exemple additionnel
  6. -
- -

Spécifications

- -

Ne fait partie d'aucune spécification. Il s'agit d'une interface propriétaire qui provient de Gecko.

- -

Gecko IDL

- -
    -
  • {{ Source("dom/webidl/XSLTProcessor.webidl", "XSLTProcessor.webidl") }}
  • -
  • {{ Source("dom/xslt/nsIXSLTProcessor.idl", "nsIXSLTProcessor.idl") }}
  • -
- -

Compatibilité des navigateurs

- -

{{Compat("api.XSLTProcessor")}}

- -

Voir aussi

- - +{{APIRef("XSLT")}} + +Un **`XSLTProcessor`** applique une transformation de feuille de style [XSLT](/en-US/docs/Web/XSLT) à un document XML pour générer un nouveau document XML. Il fait appel à des méthodes pour charger la feuille de style XSLT, donner des valeurs aux paramètres `` et pour appliquer les transformations au document. + +## Syntaxe + +Le constructeur n'a pas de paramètre. + + new XSLTProcessor() + +## Méthodes + +- `[Throws] void `{{domxref("XSLTProcessor.importStylesheet")}}`(`{{domxref("Node")}}` styleSheet)` + - : Importe une feuille de style XSLT. Si le nœud passé en argument est un nœud de document, vous pouvez passer une transformation XSL complète ou un [transformation d'élèment résultant](http://www.w3.org/TR/xslt#result-element-stylesheet); sinon, il doit s'agir d'un élèment `` ou ``. +- `[Throws] `{{domxref("DocumentFragment")}} {{domxref("XSLTProcessor.transformToFragment")}}`(`{{domxref("Node")}}` source, `{{domxref("Document")}}` owner)` + - : Transforme la source du nœud en applicant la fonction {{domxref("XSLTProcessor.importStylesheet()")}}. Le document propriétaire du fragment de document résultant est le nœud propriétaire. +- [`[Throws]`](/en-US/docs/Mozilla/WebIDL_bindings#Throws) {{domxref("Document")}} {{domxref("XSLTProcessor.transformToDocument")}}`(`{{domxref("Node")}}` source)` + + - : Transforme la source du nœud en appliquant la feuille de style donnée lors de l'importation à l'aide de la fonction {{domxref ("XSLTProcessor.importStylesheet ()")}}. + + L'objet résultant dépend de la [méthode de sortie](http://www.w3.org/TR/xslt#output) de la feuille de style : + + | Méthode de sortie | Type de résultat | + | ----------------- | ------------------------------------------------------------------------------------------------------------------- | + | `html` | {{domxref("HTMLDocument")}} | + | `xml` | {{domxref("XMLDocument")}} | + | `text` | {{domxref("XMLDocument")}} avec un seul élèment racine `` avec le texte comme enfant | + +- `[Throws] void `{{domxref("XSLTProcessor.setParameter")}}`(`{{jsxref("String")}}` namespaceURI, `{{jsxref("String")}}` localName, any value)` + - : Définit un paramètre dans la feuille de style XSLT qui a été importée. (Définit la valeur d'un ``.) Une valeur nulle pour `namespaceURI` sera traitée comme une chaîne vide. +- `[Throws] any `{{domxref("XSLTProcessor.getParameter")}}`(`{{jsxref("String")}}` namespaceURI, `{{jsxref("String")}}` localName)` + - : Récupére un paramètre de la feuille de style XSLT. Une valeur nulle pour `namespaceURI` sera traitée comme une chaîne vide. +- `[Throws] void `{{domxref("XSLTProcessor.removeParameter")}}`(`{{jsxref("String")}}` namespaceURI, `{{jsxref("String")}}` localName)` + - : Supprime le paramètre s'il a déjà été défni. Le `XSLTProcessor` utilisera alors la valeur par défaut du paramètre. Si une valeur nulle est donnée pour `namespaceURI`, elle sera traitée comme une chaîne vide. +- `void `{{domxref("XSLTProcessor.clearParameters()")}} + - : Supprime tous les paramètres définis dans le `XSLTProcessor`. Le `XSLTProcessor` utilisera alors les valeurs par défaut spécifiées dans la feuille de style XSLT. +- `void `{{domxref("XSLTProcessor.reset()")}} + - : Supprime tous les paramétres et feuilles de style du `XSLTProcessor`. + +## Propriétés + +### Propriétés non-apparentes au Web + +Les propriétés suivantes sont [`[ChromeOnly]`](/en-US/docs/Mozilla/WebIDL_bindings#ChromeOnly) et ne sont pas apparentes au contenu Web : + +- `[ChromeOnly] attribute unsigned long `{{domxref("XSLTProcessor.flags")}} + + - : Drapeaux qui modifient le comportement du processeur. Pas de réinitialisation en appelant {{domxref("XSLTProcessor.reset()")}}. Valeur par défaut: `0` + + Possible values are: + + | Nom | Valeur | Effet | + | ------------------- | ------ | --------------------------------------------------------------------------------------- | + | (None) | `0` | Aucun | + | `DISABLE_ALL_LOADS` | `1` | Désactiver le chargement de documents externes (par ex. `` et `document()`) | + +## Exemples + +1. [Exemple simple](/fr-FR/docs/XSLT/XSLT_JS_Interface_in_Gecko/Basic_Example) +2. [Exemple avancé](/fr-FR/docs/XSLT/XSLT_JS_Interface_in_Gecko/Advanced_Example) +3. [Exemple additionnel](/fr-FR/docs/XSLT/XSLT_JS_Interface_in_Gecko/JavaScript_XSLT_Bindings) + +## Spécifications + +_Ne fait partie d'aucune spécification._ Il s'agit d'une interface propriétaire qui provient de Gecko. + +## Gecko IDL + +- `{{ Source("dom/webidl/XSLTProcessor.webidl", "XSLTProcessor.webidl") }}` +- `{{ Source("dom/xslt/nsIXSLTProcessor.idl", "nsIXSLTProcessor.idl") }}` + +## Compatibilité des navigateurs + +{{Compat("api.XSLTProcessor")}} + +## Voir aussi + +- [Utilisation de l'interface JavaScript de Mozilla pour les transformations XML](/fr-FR/docs/Using_the_Mozilla_JavaScript_interface_to_XSL_Transformations) diff --git a/files/fr/web/api/xsltprocessor/xsl_transformations_in_mozilla_faq/index.md b/files/fr/web/api/xsltprocessor/xsl_transformations_in_mozilla_faq/index.md index e98799df65..59b57119e7 100644 --- a/files/fr/web/api/xsltprocessor/xsl_transformations_in_mozilla_faq/index.md +++ b/files/fr/web/api/xsltprocessor/xsl_transformations_in_mozilla_faq/index.md @@ -6,43 +6,50 @@ tags: translation_of: Web/API/XSLTProcessor/XSL_Transformations_in_Mozilla_FAQ original_slug: FAQ_sur_les_transformations_XSL_dans_Mozilla --- +#### Pourquoi ma feuille de style ne s'applique pas ? -

Pourquoi ma feuille de style ne s'applique pas ?

-

Vérifiez que le type MIME du document source et de la feuille de style est bien un type MIME XML, à savoir text/xml ou application/xml. L'espace de nommage XSLT est http://www.w3.org/1999/XSL/Transform. Utilisez l'instruction de traitement <?xml-stylesheet ?> plutôt que l'élément non standard xml:stylesheet. Le problème le plus courant est la gestion du type MIME. Pour savoir quel type MIME est envoyé par votre serveur, consultez les Informations sur la page, utilisez une extension telle que LiveHTTPHeaders (en) ou un gestionnaire de téléchargements comme wget. Mozilla ne chargera pas les feuilles de style XSLT depuis un domaine différent pour des raisons de sécurité. -

-

Cela fonctione dans IE, mais pas dans Mozilla ?

-

Il y a plus que cette "simple" différence. Nous suspectons que la plupart des différences proviennent de ce que fait IE après la transformation. IE (pour autant que l'on puisse dire) sérialise et analyse la sortie avant de générer ce qu'il rend. Mozilla, au contraire, rend exactement le résultat du votre transformation. -

-

Puis-je désactiver l'échappement de la sortie avec disable-output-escaping ?

-

Cette question est en fait très proche de la précédente. Pour faire court, non. Désactiver l'échappement en sortie nécessite que nous ajoutions une étape d'analyse à la génération de notre sortie, ce que nous ne voulons pas. Dans la plupart des cas, il existe des contournements assez facile à mettre en œuvre. Les seuls cas d'utilisation que nous ayons vu jusqu'à présent sont du mauvais XML, du mauvais XSLT, ou les flux RSS. Ce dernier est pour nous le seul problème, et nous sommes désolé de ne pouvoir le supporter, mais mélanger l'analyse avec le XSLT est à risque et nous préférons ne pas le supporter d-o-e plutôt que de provoquer des crashes ou de ralentir le processus. -

-

Que dire de document.write ?

-

Tout comme pour le XHTML, document.write n'est pas supporté pendant les transformations XSLT. Malheureusement, les compilations actuelles ne retournent pas d'erreur, mais donnent simplement des résultats inattendus, comme des crashes ({{ Bug(202765) }}). Dans la plupart des cas il n'y a en fait aucune raison de l'utiliser. Si vous avez besoin d'employer du code ou une feuille de style spécifique à une plate-forme, utilisez ce qui suit : -

-
      <xsl:if test="system-property('xsl:vendor')='Transformiix'">
-        <!-- Balisage propre à Mozilla -->
-      </xsl:if>
-      <xsl:if test="system-property('xsl:vendor')='Microsoft'">
-        <!-- Balisage propre à IE -->
-      </xsl:if>
-
-

Vérifiez system-properties.xml pour les propriétés de votre système favori. MSXML possède une propriété supplémentaire : -

-
      <xsl:if xmlns:msxsl="urn:schemas-microsoft-com:xslt"
-              test="system-property('msxsl:version')=3">
-        <!-- MSXML3 specific markup -->
-      </xsl:if>
-
-

Que dire de media="print"?

-

Lors de l'impression d'un document, Mozilla tente de produire une page imprimée aussi proche que possible de l'affichage à l'écran, en incluant par exemple le texte saisi dans des champs de formulaire, et tout autre changement dynamique. Pour cela, on imprime l'arbre DOM actuel. Utiliser une feuille de style XSLT spécifique à un media particulier requiererait une nouvelle transformation du document XML source original, ce qui pourrait produire une sortie différant de ce à quoi l'utilisateur s'attend. Aussi, l'utilisation de media dans <?xml-stylesheet ?> est fortement déconseillée. Les futures compilations pourraient ne charger une feuille de style XSLT que si media n'est pas spécifié, ou si le media spécifié comporte screen. -

Ceci n'affecte pas les feuilles de style CSS chargées depuis le DOM généré, qui emploient media comme les pages sans XSLT. -

-

Comment faire transformNode?

-

Il existe transformToDocument et transformToFragment depuis Mozilla 1.2, voir Utilisation de l'interface JavaScript de Mozilla pour les transformations XSL. -

-

Pourquoi Internet Explorer requiert-il un espace de nommage différent de celui de Mozilla ?

-

Jusqu'à sa version 6, IE requiert un espace de nommage déprécié issu d'un brouillon XSLT, merci d'utiliser Mozilla ;-), IE6+ ou MSXML3+, qui ne posent pas ce problème. Comme les différences entre XSLT 1.0 et l'implémentation dans IE de ce brouillon sont significatives, nous n'offrons pas de support. -

-

Comment compiler une version autonome de TransforMiiX ?

-

Voir l'article sur Compilation de TransforMiiX. -

\ No newline at end of file +Vérifiez que le type MIME du document source et de la feuille de style est bien un type MIME XML, à savoir `text/xml` ou `application/xml`. L'espace de nommage XSLT est `http://www.w3.org/1999/XSL/Transform`. Utilisez l'instruction de traitement `` plutôt que l'élément non standard `xml:stylesheet`. Le problème le plus courant est la gestion du type MIME. Pour savoir quel type MIME est envoyé par votre serveur, consultez les Informations sur la page, utilisez une extension telle que [LiveHTTPHeaders (en)](http://livehttpheaders.mozdev.org/) ou un gestionnaire de téléchargements comme wget. Mozilla ne chargera pas les feuilles de style XSLT depuis un domaine différent pour des raisons de sécurité. + +#### Cela fonctione dans IE, mais pas dans Mozilla ? + +Il y a plus que cette "simple" différence. Nous suspectons que la plupart des différences proviennent de ce que fait IE après la transformation. IE (pour autant que l'on puisse dire) sérialise et analyse la sortie avant de générer ce qu'il rend. Mozilla, au contraire, rend exactement le résultat du votre transformation. + +#### Puis-je désactiver l'échappement de la sortie avec `disable-output-escaping` ? + +Cette question est en fait très proche de la précédente. Pour faire court, non. Désactiver l'échappement en sortie nécessite que nous ajoutions une étape d'analyse à la génération de notre sortie, ce que nous ne voulons pas. Dans la plupart des cas, il existe des contournements assez facile à mettre en œuvre. Les seuls cas d'utilisation que nous ayons vu jusqu'à présent sont du mauvais XML, du mauvais XSLT, ou les flux RSS. Ce dernier est pour nous le seul problème, et nous sommes désolé de ne pouvoir le supporter, mais mélanger l'analyse avec le XSLT est à risque et nous préférons ne pas le supporter **d-o-e** plutôt que de provoquer des crashes ou de ralentir le processus. + +#### Que dire de `document.write` ? + +Tout comme pour le XHTML, `document.write` n'est pas supporté pendant les transformations XSLT. Malheureusement, les compilations actuelles ne retournent pas d'erreur, mais donnent simplement des résultats inattendus, comme des crashes ({{ Bug(202765) }}). Dans la plupart des cas il n'y a en fait aucune raison de l'utiliser. Si vous avez besoin d'employer du code ou une feuille de style spécifique à une plate-forme, utilisez ce qui suit : + + + + + + + + +Vérifiez system-properties.xml pour les propriétés de votre système favori. MSXML possède une propriété supplémentaire : + + + + + +#### Que dire de `media="print"`? + +Lors de l'impression d'un document, Mozilla tente de produire une page imprimée aussi proche que possible de l'affichage à l'écran, en incluant par exemple le texte saisi dans des champs de formulaire, et tout autre changement dynamique. Pour cela, on imprime l'arbre DOM actuel. Utiliser une feuille de style XSLT spécifique à un `media` particulier requiererait une nouvelle transformation du document XML source original, ce qui pourrait produire une sortie différant de ce à quoi l'utilisateur s'attend. Aussi, l'utilisation de `media` dans \ est fortement déconseillée. Les futures compilations pourraient ne charger une feuille de style XSLT que si `media` n'est pas spécifié, ou si le `media` spécifié comporte `screen`. + +Ceci n'affecte pas les feuilles de style CSS chargées depuis le DOM généré, qui emploient `media` comme les pages sans XSLT**.** + +#### Comment faire `transformNode`? + +Il existe `transformToDocument` et `transformToFragment` depuis Mozilla 1.2, voir [Utilisation de l'interface JavaScript de Mozilla pour les transformations XSL](fr/Utilisation_de_l'interface_JavaScript_de_Mozilla_pour_les_transformations_XSL). + +#### Pourquoi Internet Explorer requiert-il un espace de nommage différent de celui de Mozilla ? + +Jusqu'à sa version 6, IE requiert un espace de nommage déprécié issu d'un brouillon XSLT, merci d'utiliser Mozilla ;-), IE6+ ou MSXML3+, qui ne posent pas ce problème. Comme les différences entre XSLT 1.0 et l'implémentation dans IE de ce brouillon sont significatives, nous n'offrons pas de support. + +#### Comment compiler une version autonome de TransforMiiX ? + +Voir l'article sur [Compilation de TransforMiiX](fr/Compilation_de_TransforMiiX). -- cgit v1.2.3-54-g00ecf