2009-06-17 10 views

Antwort

19

XSLT/XPath 1.0:

<!-- a space-separated list of valid values --> 
<xsl:variable name="list" select="'7 8 9'" /> 

<xsl:if test=" 
    contains( 
    concat(' ', $list, ' '), 
    concat(' ', $k, ' ') 
) 
"> 
    <xsl:value-of select="concat('Item ', $k, ' is in the list.')" /> 
</xsl:if> 

Sie können bei Bedarf andere Trennzeichen verwenden.

In XSLT/XPath 2.0 Sie so etwas wie tun könnte:

<xsl:variable name="list" select="fn:tokenize('7 8 9', '\s+')" /> 

<xsl:if test="fn:index-of($list, $k)"> 
    <xsl:value-of select="concat('Item ', $k, ' is in the list.')" /> 
</xsl:if> 

Wenn Sie Dokumentstruktur verwenden können, um Ihre Liste zu definieren, die Sie tun können:

<!-- a node-set defining the list of currently valid items --> 
<xsl:variable name="list" select="/some/items[1]/item" /> 

<xsl:template match="/"> 
    <xsl:variable name="k" select="'7'" /> 

    <!-- test if item $k is in the list of valid items --> 
    <xsl:if test="count($list[@id = $k])"> 
    <xsl:value-of select="concat('Item ', $k, ' is in the list.')" /> 
    </xsl:if> 
</xsl:template> 
+0

Ty m8. Sein Overkill für einfaches Szenario wie ich habe, aber es ist ok für lange Listen ... Ich war mehr hopping, dass Xpath hat eine Form der integrierten Lösung .... – majkinetor

+0

Nicht XPath 1.0 - wenn Sie keine Knoten-Sets verwenden können, um Ihre zu lösen Problem Sie sind auf String-Funktionen oder vielleicht eine Erweiterungsfunktion. Die Sequenzen von XPath 2.0 erleichtern auf jeden Fall das Denken. – Tomalak

+0

Ty Tomalak :). – majkinetor

1

In XSLT 2.0, könnten Sie versuche den Range-Operator zu benutzen. Nicht sicher, ob Sie inline stringeln können?

<xsl:if test="$k = string(7 to 9)"> 

Vielleicht das Gegenteil tun und werfen $k zu einer Reihe?

<xsl:if test="number($k) = (7 to 9)"> 
Verwandte Themen