English | >> Français << | Deutsch | Magyar | 中文 | Polski ZVON > Tutorials > XSLT Tutorial
>> Page 10 << | Précédent | Suivant | Contenu | Index des éléments

Avec l'attribut mode, un élément peut être traité plusieurs fois pour générer un résultat différent à chaque fois. Dans Feuille de style XSLT 2 , l'un des modes n'existe pas.

Feuille de style XSLT 1

Source XML
<source>

<AAA id="a1" pos="start">
     <BBB id="b1"/>
     <BBB id="b2"/>
</AAA>
<AAA id="a2">
     <BBB id="b3"/>
     <BBB id="b4"/>
     <CCC id="c1">
          <CCC id="c2"/>
     </CCC>
     <BBB id="b5">
          <CCC id="c3"/>
     </BBB>
</AAA>

</source>

Sortie
<div style="color:red">CCC id=c1</div>
<div style="color:red">CCC id=c2</div>
<div style="color:red">CCC id=c3</div>
<div style="color:blue">CCC id=c1</div>
<div style="color:blue">CCC id=c2</div>
<div style="color:blue">CCC id=c3</div>
<div style="color:purple">CCC id=c1</div>
<div style="color:purple">CCC id=c2</div>
<div style="color:purple">CCC id=c3</div>

Vue HTML
CCC id=c1
CCC id=c2
CCC id=c3
CCC id=c1
CCC id=c2
CCC id=c3
CCC id=c1
CCC id=c2
CCC id=c3
Feuille de style XSLT
<xsl:stylesheet version = '1.0'
     xmlns:xsl='http://www.w3.org/1999/XSL/Transform'>

<xsl:template match="/">
     <xsl:apply-templates select="//CCC" mode="red"/>
     <xsl:apply-templates select="//CCC" mode="blue"/>
     <xsl:apply-templates select="//CCC"/>
</xsl:template>

<xsl:template match="CCC" mode="red">
     <div style="color:red">
          <xsl:value-of select="name()"/>
          <xsl:text> id=</xsl:text>
          <xsl:value-of select="@id"/>
     </div>
</xsl:template>

<xsl:template match="CCC" mode="blue">
     <div style="color:blue">
          <xsl:value-of select="name()"/>
          <xsl:text> id=</xsl:text>
          <xsl:value-of select="@id"/>
     </div>
</xsl:template>

<xsl:template match="CCC">
     <div style="color:purple">
          <xsl:value-of select="name()"/>
          <xsl:text> id=</xsl:text>
          <xsl:value-of select="@id"/>
     </div>
</xsl:template>


</xsl:stylesheet>


Feuille de style XSLT 2

Source XML
<source>

<AAA id="a1" pos="start">
     <BBB id="b1"/>
     <BBB id="b2"/>
</AAA>
<AAA id="a2">
     <BBB id="b3"/>
     <BBB id="b4"/>
     <CCC id="c1">
          <CCC id="c2"/>
     </CCC>
     <BBB id="b5">
          <CCC id="c3"/>
     </BBB>
</AAA>

</source>

Sortie
<div style="color:red">CCC id=c1</div>
<div style="color:red">CCC id=c2</div>
<div style="color:red">CCC id=c3</div>

Vue HTML
CCC id=c1
CCC id=c2
CCC id=c3
Feuille de style XSLT
<xsl:stylesheet version = '1.0'
     xmlns:xsl='http://www.w3.org/1999/XSL/Transform'>

<xsl:template match="/">
     <xsl:apply-templates select="//CCC" mode="red"/>
     <xsl:apply-templates select="//CCC" mode="yellow"/>
</xsl:template>

<xsl:template match="CCC" mode="red">
     <div style="color:red">
          <xsl:value-of select="name()"/>
          <xsl:text> id=</xsl:text>
          <xsl:value-of select="@id"/>
     </div>
</xsl:template>

<xsl:template match="CCC">
     <div style="color:purple">
          <xsl:value-of select="name()"/>
          <xsl:text> id=</xsl:text>
          <xsl:value-of select="@id"/>
     </div>
</xsl:template>


</xsl:stylesheet>