Parâmetros XSLT
Os parâmetros XSLT são adicionados ao XsltArgumentList usando o AddParam método. Um nome qualificado e um URI de namespace estão associados ao objeto de parâmetro naquele momento.
Para usar um parâmetro XSLT
Crie um XsltArgumentList objeto e adicione o parâmetro usando o AddParam método.
Chame o parâmetro da folha de estilos.
Passe o XsltArgumentList objeto para o Transform método.
Tipos de parâmetros
O objeto de parâmetro deve corresponder a um tipo W3C. A tabela a seguir mostra os tipos W3C correspondentes, as classes equivalentes do Microsoft .NET (tipo) e se o tipo W3C é um tipo XPath ou XSLT.
Tipo W3C | Classe .NET equivalente (tipo) | Tipo XPath ou XSLT |
---|---|---|
String |
System.String | XPath |
Boolean |
System.Boolean | XPath |
Number |
System.Double | XPath |
Result Tree Fragment |
System.Xml.XPath.XPathNavigator | XSLT |
Node* |
System.Xml.XPath.XPathNavigator | XPath |
Node Set |
XPathNodeIterator XPathNavigator[] |
XPath |
*Isso é equivalente a um conjunto de nós que contém um único nó.
Se o objeto de parâmetro não for uma das classes acima, ele será convertido de acordo com as seguintes regras. Os tipos numéricos CLR (Common Language Runtime) são convertidos em Double. O DateTime tipo é convertido em String. IXPathNavigable tipos são convertidos em XPathNavigator. XPathNavigator[] é convertido em XPathNodeIterator.
Todos os outros tipos lançam um erro.
Exemplo
O exemplo a seguir usa o AddParam método para criar um parâmetro para manter a data de desconto calculada. A data de desconto é calculada em 20 dias a partir da data do pedido.
using System;
using System.IO;
using System.Xml;
using System.Xml.XPath;
using System.Xml.Xsl;
public class Sample {
public static void Main() {
// Create the XslCompiledTransform and load the style sheet.
XslCompiledTransform xslt = new XslCompiledTransform();
xslt.Load("discount.xsl");
// Create the XsltArgumentList.
XsltArgumentList argList = new XsltArgumentList();
// Calculate the discount date.
DateTime orderDate = new DateTime(2004, 01, 15);
DateTime discountDate = orderDate.AddDays(20);
argList.AddParam("discount", "", discountDate.ToString());
// Create an XmlWriter to write the output.
XmlWriter writer = XmlWriter.Create("orderOut.xml");
// Transform the file.
xslt.Transform(new XPathDocument("order.xml"), argList, writer);
writer.Close();
}
}
Imports System.IO
Imports System.Xml
Imports System.Xml.XPath
Imports System.Xml.Xsl
public class Sample
public shared sub Main()
' Create the XslCompiledTransform and load the style sheet.
Dim xslt as XslCompiledTransform = new XslCompiledTransform()
xslt.Load("discount.xsl")
' Create the XsltArgumentList.
Dim argList as XsltArgumentList = new XsltArgumentList()
' Calculate the discount date.
Dim orderDate as DateTime = new DateTime(2004, 01, 15)
Dim discountDate as DateTime = orderDate.AddDays(20)
argList.AddParam("discount", "", discountDate.ToString())
' Create an XmlWriter to write the output.
Dim writer as XmlWriter = XmlWriter.Create("orderOut.xml")
' Transform the file.
xslt.Transform(new XPathDocument("order.xml"), argList, writer)
writer.Close()
end sub
end class
Entrada
order.xml
<!--Represents a customer order-->
<order>
<book ISBN='10-861003-324'>
<title>The Handmaid's Tale</title>
<price>19.95</price>
</book>
<cd ISBN='2-3631-4'>
<title>Americana</title>
<price>16.95</price>
</cd>
</order>
desconto.xsl
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:param name="discount"/>
<xsl:template match="/">
<order>
<xsl:variable name="sub-total" select="sum(//price)"/>
<total><xsl:value-of select="$sub-total"/></total>
15% discount if paid by: <xsl:value-of select="$discount"/>
</order>
</xsl:template>
</xsl:stylesheet>
Saída
<?xml version="1.0" encoding="utf-8"?>
<order>
<total>36.9</total>
15% discount if paid by: 2/4/2004 12:00:00 AM
</order>