我的 XML 是这样的
<filters>
<ISP_WebItem FILTER="Type" FILTERNAME="Malet" UNITCODE="" />
<ISP_WebItem FILTER="Mængde" FILTERNAME="500" UNITCODE="g" />
<ISP_WebItem FILTER="Anvendelse" FILTERNAME="Kaffemaskine" UNITCODE="" />
</filters>
我正在遍历每个过滤器并在单独的表格行上打印,我的代码是这样的。
<xsl:variable name="grouped-filt">
<xsl:for-each select="exslt:node-set($filt)/filters">
<xsl:apply-templates select="ISP_WebItem[generate-id() = generate-id(key('itemByFilter', @FILTER)[1])]" />
</xsl:for-each>
</xsl:variable>
<xsl:template match="ISP_WebItem">
<tr>
<td width="200px">
<xsl:value-of select="@FILTER" />
</td>
<td>
<xsl:for-each select="key('itemByFilter', @FILTER)">
<xsl:if test="position() > 1">,</xsl:if>
<xsl:value-of select="@FILTERNAME" />
<xsl:if test="@UNITCODE != ''">
<xsl:text> </xsl:text>
<xsl:value-of select="@UNITCODE"/>
</xsl:if>
</xsl:for-each>
<xsl:text> </xsl:text>
</td>
</tr>
</xsl:template>
现在我需要为每个打印的 tr 获取替代类。例子
<tr class="odd">data</tr>
<tr class="even">data</tr>
<tr class="odd">data</tr>
<tr class="even">data</tr>
任何人都可以告诉我一条路径吗?
注意:1-以上代码用于不同目的,例如对所有过滤器进行分组。2-我不能为此目的使用 JavaScript。