我试图将以下内容转换为表,但是我很难理解它如何解析所有子节点。它会遍历每个元素直到最后一个元素,还是每个父节点都需要一个for-for?另外,如果允许多次出现“ capris”,我是否需要为每个可能出现的单元格设置(例如,如果有3个最大值但我只有2个,那么我仍然需要显示3个单元格)。
XML:
<Persons xmlns = "">
<Person>
<Shirts>One</Shirts>
<Pants>
<Jeans>
<Shorts>One</Shorts>
<Capris>One</Capris>
<Capris>Two</Capris>
</Jeans>
<Dress>One</Dress>
</Pants>
</Person>
<Person>
<Shirts>One</Shirts>
<Pants>
<Jeans>
<Shorts>One</Shorts>
<Capris>One</Capris>
<Capris>Two</Capris>
<Capris>Three</Capris>
</Jeans>
<Dress>One</Dress>
</Pants>
</Person>
</Persons>
XSL:
<table border="1">
<tr bgcolor="yellow">
<td><b>Shirts</b></td>
<td><b>Shorts</b></td>
<td><b>Capris</b></td>
<td><b>Capris</b></td>
<td><b>Capris</b></td>
</tr>
<xsl:for-each select="Persons">
<xsl:sort select="Persons/Persib" />
<tr style="font-size: 10pt; font-family: verdana">
<td><xsl:value-of select="Shirts"/></td>
<td><xsl:value-of select="Shorts"/></td>
<td><xsl:value-of select="Capris"/></td>
</tr>
</xsl:for-each>
</table>
答案 0 :(得分:0)
您的xsl:for-each
匹配规则有误。
使用以下模板:它与根<Persons>
元素匹配,创建<html>
和<body>
元素以及<table>
。
最后,使用<Person>
对xsl:for-each
元素进行迭代。之所以可行,是因为上下文节点是正确的(Person
是Persons
的子节点)。
通过遍历所有Capris
元素并为每个当前元素创建一个Capris
来解决<td>
情况。您可以通过查看元素的边框来看到这一点。
需要纠正的一件事是xsl:sort
元素。它尝试按示例中不存在的<Persib>
元素的值进行排序。我想您可以自己解决此问题。
<xsl:template match="/Persons">
<html>
<body>
<table border="1">
<tr bgcolor="yellow">
<td><b>Shirts</b></td>
<td><b>Shorts</b></td>
<td><b>Capris</b></td>
<td><b>Capris</b></td>
<td><b>Capris</b></td>
</tr>
<xsl:for-each select="Person">
<xsl:sort select="Persib" />
<tr style="font-size: 10pt; font-family: verdana">
<td>
<xsl:value-of select="Shirts"/>
</td>
<td>
<xsl:value-of select="Pants/Jeans/Shorts"/>
</td>
<xsl:for-each select="Pants/Jeans/Capris">
<td>
<xsl:value-of select="." />
</td>
</xsl:for-each>
</tr>
</xsl:for-each>
</table>
</body>
</html>
</xsl:template>
输出应为所需。