COMO: Tubagem transformações de XSLT em aplicações .NET

Traduções de Artigos Traduções de Artigos
Artigo: 320847 - Ver produtos para os quais este artigo se aplica.
Expandir tudo | Reduzir tudo

Nesta página

Sumário

Este artigo demonstra como transformações XSL Transformation (XSLT) nas aplicações .NET de tubagem. O termo "Pipelining" no contexto de transformações XSLT, é o processo pelo qual os dados num documento de origem XML (Extensible Markup Language) é incrementalmente transformados por uma sequência de folhas de duas ou mais XSLT estilos para gerar o resultado final necessário. Durante o processo, o resultado é gerado por cada fase intermédio de tubagem a transformação é utilizado como a entrada para a fase seguinte todas as fases a forma através de transformação final que gera o resultado pretendido.

As classes de .NET Framework no System.Xml.xsl , System.Xml.XPath e os espaços de nomes System.IO podem ser utilizadas para programaticamente tubagem transformações de XSLT em aplicações .NET. As secções seguintes deste artigo fornecem instruções para ajudar a implementar e examinar o processo de pipelining XSLT transformações numa aplicação do ASP.NET. O conceito ilustrado também pode ser aplicado e utilizado noutros tipos de aplicações do .NET que têm de tubagem XSLT transformações.

Criar e configurar a aplicação do ASP.NET de exemplo

  1. Utilizar Visual Studio .NET para criar um novo projecto de Visual Basic .NET ASP.NET Web Application denominado "XSLTPipelineDemo" (sem as aspas).
  2. Utilize o seguinte código para criar e adicionar um documento XML denominado "Empregados.XML" (sem as aspas) para o projecto:
    <?xml version='1.0'?>
    <employees>
      <employee>
        <employeeId>1</employeeId>
        <name>
          <given>Nancy</given>
          <family>Davolio</family>
        </name>
      </employee>
      <employee>
        <employeeId>2</employeeId>
        <name>
          <given>Andrew</given>
          <family>Fuller</family>
        </name>
      </employee>
      <employee>
        <employeeId>3</employeeId>
        <name>
          <given>Janet</given>
          <family>Leverling</family>
        </name>
      </employee>  
    </employees>
    					
  3. Utilize o seguinte código para criar e adicionar uma folha de estilos XSLT denominada "sortEmployees.xslt" (sem as aspas) para o projecto. Esta folha de estilos contém código XSLT para ordenar os dados no documento XML Empregados.XML (por ordem descendente no nome da família [empregado, nome e família] elemento). O resultado é gerado quando aplicar esta folha de estilos é uma versão ordenada da origem de dados XML:
    <?xml version='1.0'?>
    
    <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
    
    <xsl:param name="sortColumn" select="'family'"/>
    <xsl:param name="sortOrder" select="'descending'"/>
    
    
    <xsl:template match="employees">
       <employees>
    
       <xsl:apply-templates select="employee/name">  
           <xsl:sort select="./*[local-name() = $sortColumn]" order="{$sortOrder}"/>            
       </xsl:apply-templates>  
    
       </employees>
    </xsl:template> 
    
    <xsl:template match="employee/name">
      <employee>
    	  <xsl:copy-of select="parent::node()/*"/>
      </employee>  
    </xsl:template> 
    
    </xsl:stylesheet>
    					
  4. Utilize o seguinte código para criar e adicionar uma folha de estilos XSLT chamada "EmployeesHTMLTable.xslt" (sem as aspas) para o projecto. Esta folha de estilos contém código XSLT para transformar a origem de dados XML Empregados (que se encontra o documento XML empregados.XML ou no XML ordenado que é gerado quando aplica a folha de estilos XSLT sortEmployees.xsl o documento XML empregados.XML ) a uma tabela HTML (Hypertext Markup Language):
    <?xml version='1.0'?>
    
    <xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
    
    <xsl:template match="employees">
    	<HTML>
    	<BODY>
    	<TABLE BORDER="1">
    	<TR>
    	  <TH>Employee ID</TH>
    	  <TH>Employee Name</TH>
    	</TR>
    
    	<xsl:for-each select="employee">
    		<TR>
      		  <TD>
    		     <xsl:value-of select="employeeId"/>
    		  </TD>
    		  <TD>
    		     <xsl:value-of select="name/family"/>, <xsl:value-of select="name/given"/>
    		  </TD>
    		</TR>
    	</xsl:for-each>
    
    	</TABLE>
    	</BODY>
    	</HTML>   
    </xsl:template> 
    
    </xsl:stylesheet>
    
    					
  5. Pode aplicar ambas as folhas de estilos XSLT independentemente um do outro para o ficheiro Empregados.XML. Aplicar sortEmployees.xsl ordena os dados no ficheiro Empregados.XML, enquanto a aplicação employeesHTMLTable.xsl gera uma representação de tabela HTML de origem XML. Para obter uma representação de tabela HTML dos dados ordenados por ordem descendente pelo nome de família, tubagem estes dois transformações de XSLT (aplique primeiro sortEmployees.xsl ao ficheiro Empregados.XML e, em seguida, aplicar employeesHTMLTable.xsl a saída gerada por transformação primeira).
  6. Copie e cole o seguinte código no procedimento de evento Page_Load de WebForm1.aspx para implementar o pipelining anteriormente descritos:
    'Load the source XML document (Employees.xml) into an XPathDocument object.
    
    Dim xmlDoc As New System.Xml.XPath.XPathDocument(Server.MapPath("employees.xml"))
    
    'Load the first stylesheet (sortEmployees.xslt) that sorts the data in employees.xml
    'into an XslTransform object.
    
    Dim xslt As New System.Xml.Xsl.XslTransform()
    xslt.Load(Server.MapPath("sortEmployees.xslt"))
    
    'Execute the first transformation and write the interim output (the sorted XML)
    'to a MemoryStream object. Using an in memory stream (as opposed to a FileStream object) 
    'to store the interim output generated by the first transformation is a better option from  
    'a performance standpoint as it avoids unnecessary disk I/O.
    
    Dim memStream As New System.IO.MemoryStream()
    xslt.Transform(xmlDoc, Nothing, memStream)
    
    'Reset the MemoryStream internal pointer to point to the 
    'beginning of the stream. This is required for the following line of 
    'code to be able to read the data from the memory stream.
    
    memStream.Position = 0
    
    'Load the interim sorted XML output in an XPathDocument object. 
    'Notice that a second XPathDocument object is created to do this. 'The reason for this is that the XPathDocument class does not implement a Load 'method (like the System.Xml.XmlDocument class) that can be used to re-load new XML data into an existing 
    'object instance. While a single XmlDocument object could have been used to execute the two pipelined 'transformations in this sample, it has not been chosen because the XPathDocument is highly optimized for XPath query 
    'execution and XSLT transformations. It is the recommended interface to use when programatically executing 
    'XSLT transformations in .NET applications.
    
    Dim interimDoc As New System.Xml.XPath.XPathDocument(memStream)
    
    'Load the second stylesheet(employeesHTMLTable.xslt)that transforms the sorted data to an HTML table
    'into the XslTransform object.
    
    xslt.Load(Server.MapPath("employeesHTMLTable.xslt"))
    
    'Execute the second transformation and stream the output directly to the 
    'ASP.Net Response object's OutputStream to display the results in the client browser.
    
    xslt.Transform(interimDoc, Nothing, Response.OutputStream)
    					
  7. Guardar e criar a solução.

Testar a aplicação do ASP.NET de exemplo

  1. Execute a aplicação do ASP.NET XSLTPiplelineDemo para iniciar e apresentação WebForm1.aspx no browser.
  2. O código no procedimento de evento Page_Load de WebForm1.aspx executa as transformações XSLT e gera o resultado sob a forma de uma tabela HTML que apresenta um ordenado (no descendente com base no nome da família) listagem dos empregados.
  3. Feche a janela do browser para sair da aplicação do ASP.NET.

Propriedades

Artigo: 320847 - Última revisão: 4 de setembro de 2003 - Revisão: 3.2
A informação contida neste artigo aplica-se a:
  • Microsoft .NET Framework 1.0
  • Microsoft .NET Framework 1.1
Palavras-chave: 
kbmt kbbcl kbhowtomaster KB320847 KbMtpt
Tradução automática
IMPORTANTE: Este artigo foi traduzido por um sistema de tradução automática (também designado por Machine translation ou MT), não tendo sido portanto revisto ou traduzido por humanos. A Microsoft tem artigos traduzidos por aplicações (MT) e artigos traduzidos por tradutores profissionais. O objectivo é simples: oferecer em Português a totalidade dos artigos existentes na base de dados do suporte. Sabemos no entanto que a tradução automática não é sempre perfeita. Esta pode conter erros de vocabulário, sintaxe ou gramática? erros semelhantes aos que um estrangeiro realiza ao falar em Português. A Microsoft não é responsável por incoerências, erros ou estragos realizados na sequência da utilização dos artigos MT por parte dos nossos clientes. A Microsoft realiza actualizações frequentes ao software de tradução automática (MT). Obrigado.
Clique aqui para ver a versão em Inglês deste artigo: 320847

Submeter comentários

 

Contact us for more help

Contact us for more help
Connect with Answer Desk for expert help.
Get more support from smallbusiness.support.microsoft.com