答案是XSLT通过xsl:if和xsl:choose实现条件判断,用xsl:for-each实现循环。xsl:if根据XPath表达式真假决定是否输出内容,适用于简单条件;当有多个互斥条件时,xsl:choose配合xsl:when和xsl:otherwise更清晰高效,能按顺序匹配首个为真的条件并输出对应结果,避免冗余判断。

XSLT实现条件判断主要依靠
xsl:if和
xsl:choose(包含
xsl:when和
xsl:otherwise),而循环则主要通过
xsl:for-each来实现。它们是XSLT转换逻辑的核心,允许我们根据XML源文档的数据动态生成不同的输出。
解决方案
Okay, so当你需要用XSLT处理XML数据,并且输出的结构不是一成不变,而是要根据数据内容来调整时,条件判断和循环简直就是你的左膀右臂。我个人觉得,理解它们的工作原理,是掌握XSLT的关键一步。
条件判断:xsl:if
和 xsl:choose
xsl:if是最直接的条件判断方式,就像其他编程语言里的
if语句一样。它接收一个
test属性,这个属性的值是一个XPath表达式。如果XPath表达式的计算结果为真(比如节点存在,或者某个值符合条件),那么
xsl:if标签内部的内容就会被处理并输出。
举个例子,假设我们想根据产品的库存状态来显示不同的文本:
<products>
<product id="1">
<name>Laptop</name>
<stock>10</stock>
</product>
<product id="2">
<name>Mouse</name>
<stock>0</stock>
</product>
</products>XSLT里可以这样写:
<xsl:template match="product">
<h3><xsl:value-of select="name"/></h3>
<xsl:if test="stock > 0">
<p>库存充足,赶紧购买!</p>
</xsl:if>
<xsl:if test="stock = 0">
<p style="color: red;">抱歉,已售罄。</p>
</xsl:if>
</xsl:template>这里你会发现,如果需要处理多个互斥的条件,用一系列
xsl:if可能会显得有点冗余,甚至在某些情况下,逻辑上可能会出问题(尽管在这个例子里不会)。这时候,
xsl:choose就显得更加优雅和强大了。
xsl:choose就像其他语言里的
switch或
if-else if-else结构。它内部包含一个或多个
xsl:when元素,每个
xsl:when也有一个
test属性。XSLT处理器会按顺序评估这些
xsl:when,一旦某个
test条件









