Beispiel für <xsl:call-template>
Im folgenden Beispiel wird das <xsl:call-template>
-Element zum modularen Transformieren von XSLT verwendet. Im Beispiel werden drei Hauptdateien verwendet:
Die XML-Quelldatei topic.xml. Diese Datei stellt ein Thema in einer Buchveröffentlichung dar.
Die XSLT-Hauptdatei topic.xsl. Mit dieser Datei wird bestimmt, welche Informationen angezeigt werden.
Die aufgerufene XSLT-Datei ui.xsl. Mit dieser Datei wird bestimmt, wie die Informationen gerendert werden.
XML-Datei (topic.xml)
XSLT-Hauptdatei (topic.xsl)
XSLT-Komponentendatei (ui.xsl)
Ausgabe
Die formatierte Ausgabe lautet:
My Topic
First Paragraph
The first para has both name and title.
Second Paragraph
the second para has a title but no name.
Third para has neither name nor title.
Die Prozessorausgabe lautet:
<H2 CONTENTEDITABLE="true">My Topic</H2>
<P>
<DIV STYLE="font-size:16;
font-family:Arial;
font-weight:bold;
font-style:italic"
CONTENTEDITABLE="true">First Paragraph<DIV>
<SPAN CONTENTEDITABLE="true">
The first para has both name and title.
</SPAN>
</P>
<P>
<DIV STYLE="font-size:16;
font-family:Arial;
font-weight:bold;
font-style:italic"
CONTENTEDITABLE="true">Second Paragraph<DIV>
<SPAN CONTENTEDITABLE="true">
The second para has a title but no name.
</SPAN>
</P>
<P>
<SPAN CONTENTEDITABLE="true">
The third para has neither name nor title.
</SPAN>
</P>
Hinweise
Mit der XSLT-Hauptdatei topic.xsl wird bestimmt, welche Informationen angezeigt werden. Der Inhalt des <meta>
-Elements wird ausgeblendet, und die Reihenfolge der angezeigten Elemente wird bestimmt. Mithilfe der Datei werden zudem Vorlagenregeln aufgerufen, die in der XSLT-Komponentendatei ui.xsl definiert sind.
Die Datei ui.xsl enthält ausschließlich benannte Vorlagenregeln, die aus der ersten XSLT-Datei abgerufen werden können. Jede benannte Vorlagenregel verhält sich wie eine reguläre Funktion. Sie nimmt die beiden Eingabeparameter $value
und $editable
an und erstellt eine HTML-Ausgabe. Der $value
-Parameter übergibt den anzuzeigenden Text. Mithilfe von $editable
wird bestimmt, ob der Ausgabetext bearbeitet werden kann (bei Verwendung von Internet Explorer). Im Gegensatz zu einer regulären Funktion muss die Reihenfolge der Eingabeparameter in der benannten Vorlagenregel nicht der in der aufrufenden Vorlagenregel angegebenen Reihenfolge entsprechen.
Beachten Sie, dass die Vorlagenregeln nicht von den im XML-Quelldokument definierten Knoten abhängig sind. Daher ist die Datei ui.xsl ein Beispiel dafür, wie Sie eine UI-Bibliothek für allgemeine Zwecke schreiben können, die aus beliebigen anderen XSLT-Dateien aufgerufen werden kann.