Skip to main content

XSLT <xsl:xsl:apply-templates>

XSLT <xsl:xsl:apply-templates>

The <xsl:apply-templates> element applies a template to the current element or to the current element's child nodes.

If we add a select attribute to the <xsl:apply-templates> element, it will process only the child element that matches the value of the attribute.

We can use the select attribute to specify in what order the child nodes should be processed.

Syntax

<xsl:apply-templates select="expression"  mode="name">  

<!-- Content:(xsl:sort|xsl:with-param)* -->

</xsl:apply-templates>

Attributes

AttributeValueRequired/OptionalDescription
selectexpressionOptionalSpecifies the nodes to be processed. An asterisk selects the entire node-set. If this attribute is omitted, all child nodes of the current node will be selected
modenameOptionalIf there are multiple ways of processing defined for the same element, distinguishes among them

Example

Let's see some examples:

Example 1

Wrap a single <h1> element around each title element in the document:

example1.xsl
<?xml version="1.0"  encoding="UTF-8"?>  
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:template match="title">
<h1><xsl:apply-templates/></h1>
</xsl:template>

</xsl:stylesheet>

Example 2

Wrap a single <h1> element around all the title elements which are children of message:

example2.xsl
<?xml version="1.0"  encoding="UTF-8"?>  
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:template match="message">
<h1><xsl:apply-templates select="title"/></h1>
</xsl:template>

</xsl:stylesheet>

Example 3

Wrap a single <h1> element around all the child nodes of message that have the mode attribute set to "big":

example3.xsl
<?xml version="1.0"  encoding="UTF-8"?>  
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">

<xsl:template match="message">
<h1><xsl:apply-templates select="*" mode="big"/></h1>
</xsl:template>

</xsl:stylesheet>