我必须使用XSLT将XML文档转换为Bootstrap表。我在使用PHP之前就已经做到了,它非常简单,我正在尝试在XSLT中对其进行调整。
使用PHP,我做了这样的事情:
while($line = $request->fetch(PDO::FETCH_ASSOC))
{
echo '<tr ';
switch($line["category"])
{
case "Movie" : echo "class='info'";break;
case "Tv show" : echo "class='danger'";break;
case "Music" : echo "class='success'";break;
}
echo ' >';
...
echo "</tr>";
}
我试图在XSLT中执行类似的代码(不使用串联,因为我们不能这样做):
<xsl:for-each select="demands/demand">
<xsl:choose>
<xsl:when test="category = 'Movie'">
<tr class="info">
</xsl:when>
<xsl:when test="category = 'Tv show'">
<tr class="danger">
</xsl:when>
<xsl:when test="categorie = 'Music'">
<tr class="success">
</xsl:when>
</xsl:choose>
...
</tr>
</xsl:for-each>
这是行不通的(“开始和结束标记不匹配:tr行”),因为只有一个结束tr标记。有什么解决办法吗?我如何做到最简单的方式?
谢谢你的帮助。
Martin Honnen解决方案的一种变体,具有更多的代码重用性,是
<xsl:template match="demands/demand">
<tr>
<xsl:attribute name="class">
<xsl:apply-templates select="@category"/>
</xsl:attribute>
<xsl:apply-templates/>
</tr>
</xsl:template>
<xsl:template match="@category[. = 'Movie']"
>info</xsl:template>
<xsl:template match="@category[. = 'Tv show']"
>danger</xsl:template>
<xsl:template match="@category[. = 'Music']"
>success</xsl:template>
本文收集自互联网,转载请注明来源。
如有侵权,请联系 [email protected] 删除。
我来说两句