我需要从 XSLT 文件以 html 格式创建一个表,但只选择一组特定的节点。例如,在以下 XML 中,我希望选择 routename 包含 fco-dxb 的所有 from 和 to 子节点:
<?xml version="1.0" encoding="UTF-8"?>
<flights
xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="flights.xsd">
<flight flightid="1">
<flightno>EK98</flightno>
<callsign>UAE98</callsign>
<airline>Emirates Airline</airline>
<plane planeid="1">
<name>Airbus A380-861</name>
<registereddate>07-06-10</registereddate>
</plane>
<registration>3A6-EDJ</registration>
<altitude height="feet">41000</altitude>
<speed ratio="mph">564</speed>
<distance unit="miles">erf</distance>
<route>
<routename>FCO-DXB</routename>
<from>
<iatacode>FCO</iatacode>
<airport>Fiumicino</airport>
<country>Italy</country>
<city>Rome</city>
<latitude>41.8044</latitude>
<longitude>12.2508</longitude>
</from>
<to>
<iatacode>DXB</iatacode>
<airport>Dubai Intl</airport>
<country>United Arab Emirates</country>
<city>Dubai</city>
<latitude>25.2528</latitude>
<longitude>55.3644</longitude>
</to>
</route>
<course bearing="degrees">154</course>
<journey>
<distance type="miles">2,697</distance>
<time>PT5H30M</time>
</journey>
</flight>
<flight flightid="2">
<flightno>BA283</flightno>
<callsign>BAW283</callsign>
<airline>British Airways</airline>
<plane planeid="2">
<name>Boeing 747-436</name>
<registereddate>06-12-97</registereddate>
</plane>
<registration>3A6-EDJ</registration>
<altitude height="feet">41000</altitude>
<speed ratio="mph">564</speed>
<distance unit="miles">erf</distance>
<route>
<routename>LHR-LAX</routename>
<from>
<iatacode>LHR</iatacode>
<airport>Heathrow</airport>
<country>England</country>
<city>London</city>
<latitude>51.4775</latitude>
<longitude>0.4614</longitude>
</from>
<to>
<iatacode>LAX</iatacode>
<airport>Los Angeles International</airport>
<country>United States of America</country>
<city>L.A</city>
<latitude>33.9471</latitude>
<longitude>-118.4082</longitude>
</to>
</route>
<course bearing="degrees">154</course>
<journey>
<distance type="miles">5,441 miles</distance>
<time>PT11H5M</time>
</journey>
</flight>
</flights>
并将其输出到表格中,这是我在 XSLT 中的尝试:
<?xml version="1.0"?>
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="html" omit-xml-declaration="yes" />
<xsl:template match="/">
<xsl:element name="html">
<xsl:element name="head">
<xsl:element name="title">flights</xsl:element>
</xsl:element>
<xsl:element name="body">
<xsl:element name="table"><xsl:attribute name="border">1</xsl:attribute>
<xsl:element name="tr">
<xsl:element name="td">
<xsl:element name="b">Title</xsl:element>
</xsl:element>
<xsl:element name="td">
<xsl:element name="b">Artist</xsl:element>
</xsl:element>
<xsl:element name="td">
<xsl:element name="b">Year</xsl:element>
</xsl:element>
</xsl:element>
<xsl:apply-templates select="flights/flight/route[contains(text(), 'FCO-DXB')]" />
</xsl:element>
</xsl:element>
</xsl:element>
</xsl:template>
<xsl:template match="from">
<xsl:element name="tr">
<xsl:element name="td"><xsl:value-of select="iatacode"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="airport"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="country"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="city"/></xsl:element>
</xsl:element>
</xsl:template>
<xsl:template match="to">
<xsl:element name="tr">
<xsl:element name="td"><xsl:value-of select="iatacode"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="airport"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="country"/></xsl:element>
<xsl:element name="td"><xsl:value-of select="city"/></xsl:element>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
我的目标是最终弄清楚如何将参数传递给 XSLT 文件,因此我可以将参数传递给它,而不是硬编码包含文本,但到目前为止我只想知道如何回答这个问题。