为xsl:foreach循环中的备用表行应用备用类名



我的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() &gt; 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>&#10;</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>

谁能给我指路吗?

注意:上面的代码有不同的用途,比如对所有过滤器进行分组。

你可以直接在模板中使用位置函数,就像你在for-each:

中使用它一样。
<xsl:template match="ISP_WebItem">
    <tr>
       <xsl:attribute name="class">
         <xsl:choose>
           <xsl:when test="(position() mod 2) = 0">even</xsl:when>
           <xsl:otherwise>odd</xsl:otherwise>
         </xsl:choose>
       </xsl:attribute>

position()基于调用apply-templates所选择的节点列表,即给定

<xsl:apply-templates select="ISP_WebItem[generate-id() = generate-id(key('itemByFilter', @FILTER)[1])]" />

按文档顺序选择的第一个ISP_WebItem将具有position() = 1,第二个position() = 2,依此类推。

尝试:

<xsl:when test="position() mod 2">

</xsl:when>

我认为这是可能的使用一些像这样的javascript

$(document).ready(function(){
$(".pdfgrid tr:even").addClass('even');
$(".pdfgrid tr:odd").addClass('odd');
});

相关内容

  • 没有找到相关文章

最新更新