Поделиться через


Параметры XSLT

Параметры XSLT добавляются в XsltArgumentList с помощью метода AddParam. Полное имя и универсальный код ресурса (URI) пространства имен связаны с объектом параметра в то время.

Использование параметра XSLT

  1. XsltArgumentList Создайте объект и добавьте параметр с помощью AddParam метода.

  2. Вызовите параметр из таблицы стилей.

  3. XsltArgumentList Передайте объект методуTransform.

Типы параметров

Объект параметра должен соответствовать типу W3C. В следующей таблице показаны соответствующие типы W3C, эквивалентные классы Microsoft .NET (тип), а также тип W3C — тип XPath или XSLT.

Тип W3C Эквивалентный класс .NET (тип) Тип XPath или 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

*Это эквивалентно набору узлов, который содержит один узел.

Если объект параметра не является одним из указанных выше классов, он преобразуется в соответствии со следующими правилами. Числовые типы в общей языковой среде CLR преобразуются в Double. Тип DateTime преобразуется в String. IXPathNavigable типы преобразуются в XPathNavigator. XPathNavigator[] преобразуется в XPathNodeIterator.

Все остальные типы вызывают ошибку.

Пример

В следующем примере метод используется AddParam для создания параметра для хранения вычисляемой даты скидки. Дата скидки рассчитывается на 20 дней с даты заказа.

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

Ввод

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>
discount.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>

Выходные данные

<?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>  

См. также